1.####################################################################################
try {
/**
* 1 反射出无参的构造方法并得到对象
* 注意:
* 1 在Class.forName()中应该传入含有包名的类全名
* 2 newInstance()方法的本质是调用类的无参Public构造方法
*/
String className1="cn.testreflect.Worker";
Class clazz1=Class.forName(className1);
Object object1=clazz1.newInstance();
System.out.println("object1.toString()="+object1.toString());
/**
* 2 反射出带参数的构造方法并得到对象
*/
String className2="cn.testreflect.Worker";
Class clazz2=Class.forName(className2);
Constructor constructor1=clazz2.getConstructor(int.class,String.class);
Object object2=constructor1.newInstance(18,"小明");
System.out.println("object2.toString()="+object2.toString());
/**
* 3 获取类的私有字段
* 注意:
* 获取共有字段应调用clazz3.getField(name)方法
*/
String className3="cn.testreflect.Worker";
Class clazz3=Class.forName(className3);
Field ageField1=clazz3.getDeclaredField("age");
System.out.println("ageField1="+ageField1);
/**
* 4 获取和更改某个对象的私有字段
* 即模拟get()和set()方法
*/
String className4="cn.testreflect.Worker";
Class clazz4=Class.forName(className4);
Field ageField2=clazz4.getDeclaredField("age");
Object object4=constructor1.newInstance(18,"小明");
//取消访问私有字段的合法性检查
ageField2.setAccessible(true);
//获取对象的私有字段
Object ageObject4=ageField2.get(object4);
System.out.println("ageObject4="+ageObject4);
//再更改对象的私有字段的值
ageField2.set(object4, 9527);
//重新获得
Object ageObject5=ageField2.get(object4);
System.out.println("ageObject5="+ageObject5);
/**
* 5 调用对象的带参数的方法
*/
String className5="cn.testreflect.Worker";
Class clazz5=Class.forName(className5);
Method method=clazz5.getMethod("printMessage", String.class,int.class,int.class);
Object object5=clazz5.newInstance();
method.invoke(object5, "周星星",50,9527);
} catch (Exception e) {
System.out.println(e.toString());
}
2.######################################################################################################
有时候我们需要对一个静态类使用反射机制,来激活静态类内部的静态方法,用System静态类举例如下:
System.class.getMethod("setProperty", new Class[]{String.class,String.class}).invoke(null,"app_name","app_name_value");
这行代码等价于
System.setProperty("app_name","app_name_value")
其中getMethod中除了需要传入方法的名称外,还需要正确的传入方法内的参数类型数组,用以区分方法名相同但参数不同的重载类的方法。
invoke的第一个参数传入的是要激活方法的对象,如果是静态类本身,则直接传null就可以了。
try {
/**
* 1 反射出无参的构造方法并得到对象
* 注意:
* 1 在Class.forName()中应该传入含有包名的类全名
* 2 newInstance()方法的本质是调用类的无参Public构造方法
*/
String className1="cn.testreflect.Worker";
Class clazz1=Class.forName(className1);
Object object1=clazz1.newInstance();
System.out.println("object1.toString()="+object1.toString());
/**
* 2 反射出带参数的构造方法并得到对象
*/
String className2="cn.testreflect.Worker";
Class clazz2=Class.forName(className2);
Constructor constructor1=clazz2.getConstructor(int.class,String.class);
Object object2=constructor1.newInstance(18,"小明");
System.out.println("object2.toString()="+object2.toString());
/**
* 3 获取类的私有字段
* 注意:
* 获取共有字段应调用clazz3.getField(name)方法
*/
String className3="cn.testreflect.Worker";
Class clazz3=Class.forName(className3);
Field ageField1=clazz3.getDeclaredField("age");
System.out.println("ageField1="+ageField1);
/**
* 4 获取和更改某个对象的私有字段
* 即模拟get()和set()方法
*/
String className4="cn.testreflect.Worker";
Class clazz4=Class.forName(className4);
Field ageField2=clazz4.getDeclaredField("age");
Object object4=constructor1.newInstance(18,"小明");
//取消访问私有字段的合法性检查
ageField2.setAccessible(true);
//获取对象的私有字段
Object ageObject4=ageField2.get(object4);
System.out.println("ageObject4="+ageObject4);
//再更改对象的私有字段的值
ageField2.set(object4, 9527);
//重新获得
Object ageObject5=ageField2.get(object4);
System.out.println("ageObject5="+ageObject5);
/**
* 5 调用对象的带参数的方法
*/
String className5="cn.testreflect.Worker";
Class clazz5=Class.forName(className5);
Method method=clazz5.getMethod("printMessage", String.class,int.class,int.class);
Object object5=clazz5.newInstance();
method.invoke(object5, "周星星",50,9527);
} catch (Exception e) {
System.out.println(e.toString());
}
2.######################################################################################################
有时候我们需要对一个静态类使用反射机制,来激活静态类内部的静态方法,用System静态类举例如下:
System.class.getMethod("setProperty", new Class[]{String.class,String.class}).invoke(null,"app_name","app_name_value");
这行代码等价于
System.setProperty("app_name","app_name_value")
其中getMethod中除了需要传入方法的名称外,还需要正确的传入方法内的参数类型数组,用以区分方法名相同但参数不同的重载类的方法。
invoke的第一个参数传入的是要激活方法的对象,如果是静态类本身,则直接传null就可以了。