1.what?
java反射机制就是根据一个Class对象能获得该类中的成员属性、方法以及构造函数等信息,并且能以此来创建该类的对象,以及调用该类相应的方法。
2.why?
java程序中的很多对象都会有两种类型:编译时类型和运行时类型。编译时类型就是指编译的时候就能确定该对象的类型,从而可以直接调用该类中的方法,运行时类型是指该对象的类型需要在运行时才能确定,比如有个函数的输入参数是Object,但是在该函数中,又需要调用该Object对象运行时的方法,这个时候就需要使用java的反射机制。
java反射在各种开发框架的设计中使用较多,平时的开发使用较少。
3.how?
实现java反射机制的根本是,JVM在加载每个类到内存中的时候,会对每个类生产一个Class对象,而这个Class对象保存了该类的成员属性、方法以及构造函数等信息,因此java反射机制从每个类的Class对象入手来获取每个类的信息。
package reflecttest;
import java.lang.reflect.Constructor;
import java.lang.reflect.Field;
import java.lang.reflect.Method;
class Person{
private String name;
public int age;
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
public Person(){
System.out.println("Person()构造函数");
}
public Person(String name, int age){
System.out.println("Person(String name, int age)构造函数");
this.name = name;
this.age = age;
}
private void hello(String s, int a){
System.out.println("hello:"+this.name+":"+this.age+":"+s+":"+a);
}
}
public class ReflectTest {
public static void main(String[] args) throws Exception {
Class<?> classType1 = Class.forName("reflecttest.Person");//通过Class.forName()获取Class对象
Constructor<?> ctor1 = classType1.getConstructor(new Class[]{String.class, int.class});//获取指定参数类型的构造函数
Object p1 = ctor1.newInstance(new Object[]{"lisi", 'l'});//创建该类的一个实例
p1 = classType1.newInstance();//调用默认构造函数创建该类的一个实例
Person p2 = new Person();
Class<? extends Person> classType2 = p2.getClass();//使用getClass()方法获取该Class对象
p2 = classType2.newInstance();
Field f1 = classType1.getDeclaredField("name"); //获取类的成员属性,Declared可以返回private修饰的方法或成员
f1.setAccessible(true);//对于private修饰的成员或者方法需要使用setAccessible(true)来取消java对访问权限的限制,否则将不能访问private修饰的成员
f1.set(p1, "zhaowu");
Field f2 = classType1.getField("age");//age是public修饰的
f2.set(p1, 'z');
Method m1 = classType1.getDeclaredMethod("hello", new Class[]{String.class, int.class});//获取方法
m1.setAccessible(true);
m1.invoke(p1, new Object[]{"keqi", 'k'});//使用invoke调用方法
}
}
运行结果:
Person(String name, int age)构造函数
Person()构造函数
Person()构造函数
Person()构造函数
hello:zhaowu:122:keqi:107
Person()构造函数
Person()构造函数
Person()构造函数
hello:zhaowu:122:keqi:107