標籤:函數調用 架構 java反射 對象 clone() java開發 序列化 構造器 ons
轉自: https://www.cnblogs.com/baizhanshi/p/5896092.html
作為java開發人員,我們每天建立很多個物件,但是我們通常使用依賴注入的方式管理系統,比如:Spring去建立對象,然而這裡有很多建立對象的方法:使用New關鍵字、使用Class類的newInstance方法、使用Constructor類的newInstance方法、使用Clone方法、使用還原序列化。
- 使用new關鍵字:這是我們最常見的也是最簡單的建立對象的方式,通過這種方式我們還可以調用任意的夠贊函數(無參的和有參的)。比如:Student student = new Student();
- 使用Class類的newInstance方法:我們也可以使用Class類的newInstance方法建立對象,這個newInstance方法調用無參的構造器建立對象,如:Student student2 = (Student)Class.forName("根路徑.Student").newInstance(); 或者:Student stu = Student.class.newInstance();
- 使用Constructor類的newInstance方法:本方法和Class類的newInstance方法很像,java.lang.relect.Constructor類裡也有一個newInstance方法可以建立對象。我們可以通過這個newInstance方法調用有參數的和私人的建構函式。如: Constructor<Student> constructor = Student.class.getInstance(); Student stu = constructor.newInstance(); 這兩種newInstance的方法就是大家所說的反射,事實上Class的newInstance方法內部調用Constructor的newInstance方法。這也是眾多架構Spring、Hibernate、Struts等使用後者的原因。
- 使用Clone的方法:無論何時我們調用一個對象的clone方法,JVM就會建立一個新的對象,將前面的對象的內容全部拷貝進去,用clone方法建立對象並不會調用任何建構函式。要使用clone方法,我們必須先實現Cloneable介面並實現其定義的clone方法。如:Student stu2 = <Student>stu.clone();這也是原型模式的應用。
- 使用還原序列化:當我們序列化和還原序列化一個對象,JVM會給我們建立一個單獨的對象,在還原序列化時,JVM建立對象並不會調用任何建構函式。為了還原序列化一個對象,我們需要讓我們的類實現Serializable介面。如:ObjectInputStream in = new ObjectInputStream (new FileInputStream("data.obj")); Student stu3 = (Student)in.readObject();
從上面的例子可以看出來,除了使用new關鍵字之外的其他方法全部都是轉變為invokevirtual(建立對象的直接方法),使用被new的方式轉變為兩個調用,new和invokespecial(建構函式調用)。
另外:兩種newInstance方法有沒有區別?
☆ Class類位於java的lang包中,而構造器類是java反射機制的一部分。
☆ Class類的newInstance只能觸發無參數的構造方法建立對象,而構造器類的newInstance能觸發有參數或者任意參數的構造方法來建立對象。
☆ Class類的newInstance需要其構造方法是共有的或者對調用方法可見的,而構造器類的newInstance可以在特定環境下調用私人構造方法來建立對象。
☆ Class類的newInstance拋出類建構函式的異常,而構造器類的newInstance封裝了一個InvocationTargetException異常。
Class類本質上調用了反射包構造器類中無參數的newInstance方法,捕獲了InvocationTargetException,將構造器本身的異常拋出。
Java中建立對象的幾種方式