1.存在無參構造的情況:
public T newInstance()
throws InstantiationException, IllegalAccessException
除了第一種方法(getClass())會産生Date類的執行個體化對象之外,其他的兩種都不會産生Date類的執行個體化對象。
于是取得了Class類對象有一個最直接的好處:可以通過反射執行個體化對象。
public class Test {public static void main(String[] args) throws
ClassNotFoundException,InstantiationException, IllegalAccessException {
Class<?> cls = Class.forName("java.util.Date") ;
// 執行個體化對象,等價于 new java.util.Date();
Object obj = cls.newInstance() ;
System.out.println(obj);}
}
2.不存在無參構造的情況
public T newInstance(Object ... initargs) throws
InstantiationException, IllegalAccessException,IllegalArgumentException, InvocationTargetExceptio
Class類通過反射執行個體化類對象的時候,隻能夠調用類中的無參構造。如果現在類中沒有無參構造則無法使用Class類調用,隻能夠通過明确的構造調用執行個體化處理。
package getConstructioMethod;
import java.lang.reflect.Constructor;
import java.lang.reflect.InvocationTargetException;
class Person {
private String name ;
private int age ;
public Person(String name,int age) {
this.name = name ;this.age = age ;
}
@Override
public String toString() {
return "Person [name=" + name + ", age=" + age + "]";
}
}
public class Test {public static void main(String[] args) throws InstantiationException,IllegalAccessException, NoSuchMethodException, SecurityException,IllegalArgumentException, InvocationTargetException {
Class<?> cls = Person.class ;// 取得指定參數類型的構造方法對象
Constructor<?> cons = cls.getConstructor(String.class,int.class);
System.out.println(cons.newInstance("fwb",21));
}
}