天天看點

【反射2】通過反射執行個體化對象

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