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));
}
}