天天看點

java new newinstance_java中newInstance()和new()

https://blog.csdn.net/wistbean/article/details/80964377

在初始化一個類,生成一個執行個體的時候;newInstance() 和 new 有什麼差別?

用newInstance與用new是差別的,差別在于建立對象的方式不一樣,前者是使用類加載機制,那麼為什麼會有兩種建立對象方式?這個就要從可伸縮、可擴充,可重用等軟體思想上解釋了。

Java中工廠模式經常使用newInstance來建立對象,是以從為什麼要使用工廠模式上也可以找到具體答案。

例如:

Class c = Class.forName(“A”);factory = (AInterface)c.newInstance();

其中AInterface是A的接口,如果下面這樣寫,你可能會了解:

String className = “A”;Class c = Class.forName(className);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時候,就必須保證:1、這個類已經加載;2、這個類已經連接配接了。而完成上面兩個步驟的正是class的靜态方法forName()方法,這個靜态方法調用了啟動類加載器(就是加載javaAPI的那個加載器)。

有了上面jvm上的了解,那麼我們可以這樣說,newInstance實際上是把new這個方式分解為兩步,即,首先調用class的加載方法加載某個類,然後執行個體化。

這樣分步的好處是顯而易見的。我們可以在調用class的靜态加載方法forName時獲得更好的靈活性,提供給了我們降耦的手段。

[補充:]

newInstance: 弱類型。低效率。隻能調用無參構造。

new: 強類型。相對高效。能調用任何public構造。

newInstance()是實作IOC、反射、面對接口程式設計 和 依賴倒置 等技術方法的必然選擇,new 隻能實作具體類的執行個體化,不适合于接口程式設計。

裡面就是通過這個類的預設構造函數建構了一個對象,如果沒有預設構造函數就抛出InstantiationException, 如果沒有通路預設構造函數的權限就抛出IllegalAccessException

首先兩者都是用來建立對象的。但是他們的差別如下:

1>.new是一個關鍵字;而newInstance是Class類中的一個方法,并且應用到了反射機制,相當于逆向建立對象,而new則是順序建立對象。

2>.new可以在喲個類還沒有加載的時候使用;而newInstance使用之前該類一點要被加載,已經被連接配接(Class.forName("...")).

3>.new可以調用類中任何public構造方法;而newInstance隻能調用無參構造。

4>.new是強類型的,相對高效;而newInstance是弱類型的,效率較低。

廢話少說,上代碼:

@Test

public void getInstance() throws ClassNotFoundException, InstantiationException, IllegalAccessException {

String classValue = "com.sunhui.test.Student";

Class clazz = Class.forName(classValue);          //初始化該類

Student student = (Student) clazz.newInstance(); //執行個體化該類

student.setUserName("sunhui");

student.setPassword("sh152332");

System.out.println("UserName:"+student.getUserName()+"\nPassword:"+student.getPassword());

}

二、代碼解釋:

forName()傳回的是一個類(Object),它可以強制轉換成各種子類。在使用這個方法時,JVM會查找并加載指定的類,也就是說JVM會執行該類的靜态代碼段。

newInstance()傳回的是一個類的對象。

三、從JVM的角度:

使用newInstance的條件:

1、這個類已經加載

2、這個類已經連接配接了。

使用new的條件:

該類可以沒有加載。(不是一定)

四、注意:

newInstance()是實作IOC、反射、面對接口程式設計和依賴倒置等技術方法的必然選擇,new 隻能實作具體類的執行個體化,不适合于接口程式設計。newInstance裡面就是通過這個類的預設構造函數建構了一個對象,必須要有預設構造函數,如果沒有預設構造函數就抛出InstantiationException, 如果沒有通路預設構造函數的權限就抛出IllegalAccessException。

五、總結:

newInstance()就是把new這個方式分解為兩步,首先調用class的加載方法加載某個類,然後執行個體化。這樣的好處是顯而易見的。

1、我們可以在調用class的靜态方法forName()時獲得更好的靈活性

2、提供給了我們降耦的手段。

https://www.cnblogs.com/houziwty/p/5409344.html

https://yinter.iteye.com/blog/430865