在初始化一個類,生成一個實例的時候,newInstance() 和 new 有什麼區別?
用newInstance與用new是區別的,區別在於建立對象的方式不同,前者是使用類加載機制,那麼爲何會有兩種建立對象方式?這個就要從可伸縮、可擴展,可重用等軟件思想上解釋了。Java中工廠模式常常使用newInstance來建立對象,所以從爲何要使用工廠模式上也能夠找到具體答案。
例如:
Class c = Class.forName(「A」); java
factory = (AInterface)c.newInstance();
其中AInterface是A的接口,若是下面這樣寫,你可能會理解:
String className = 「A」; 編程
Class c = Class.forName(className); jvm
factory = (AInterface)c.newInstance();
進一步,若是下面寫,你可能會理解:
String className = readfromXMlConfig;//從xml 配置文件中得到字符串 函數
Class c = Class.forName(className);factory = (AInterface)c.newInstance();
上面代碼就消滅了A類名稱,優勢:不管A類怎麼變化,上述代碼不變,甚至能夠更換A的兄弟類B , C , D….等,只要他們繼承Ainterface就能夠。
從jvm的角度看,咱們使用new的時候,這個要new的類能夠沒有加載;
可是使用newInstance時候,就必須保證:一、這個類已經加載;二、這個類已經鏈接了。而完成上面兩個步驟的正是class的靜態方法forName()方法,這個靜態方法調用了啓動類加載器(就是加載javaAPI的那個加載器)。
有了上面jvm上的理解,那麼咱們能夠這樣說,newInstance其實是把new這個方式分解爲兩步,即,首先調用class的加載方法加載某個類,而後實例化。
這樣分步的好處是顯而易見的。咱們能夠在調用class的靜態加載方法forName時得到更好的靈活性,提供給了咱們降耦的手段。 spa
[補充:]
newInstance: 弱類型。低效率。只能調用無參構造。
new: 強類型。相對高效。能調用任何public構造。
newInstance()是實現IOC、反射、依賴倒置 等技術方法的必然選擇,new 只能實現具體類的實例化,不適合於接口編程。類裏面就是經過這個類的默認構造函數構建了一個對象,若是沒有默認構造函數就拋出InstantiationException, 若是沒有訪問默認構造函數的權限就拋出IllegalAccessException xml