反射可以通过类名获取到对应的Class,可以通过方法名获取到Method并通过invoke方法调用获取到的方法.
反射机制能做什么反射机制主要提供了以下功能:
1.在运行时判断任意一个对象所属的类;
2.在运行时构造任意一个类的对象;
3.在运行时判断任意一个类所具有的成员变量和方法;
4.在运行时调用任意一个对象的方法;
5.生成动态代理;
6.进行反编译:.class(字节码文件)-->.java(源代码文件);
应用场景:这样一个应用程序,它支持动态的功能扩展,也就是说程序不重新启动但是可以自动加载新的功能,这个功能使用一个具体类来表示。首先我们必须为这些功能定义一个接口类,然后我们要求所有扩展的功能类必须实现我指定的接口,这个规定了应用程序和可扩展功能之间的接口规则,但是怎么动态加载呢?我们必须让应用程序知道要扩展的功能类的类名,比如是test.Func1,当我们把这个类名(字符串)告诉应用程序后,它就可以使用我们第一个例子的方法来加载并启用新的功能。这就是类的反射.
public class TestReflection {
String name;
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public static void main(String args[]) throws Exception {
Class clazz=Class.forName("TestReflection");
TestReflection reflection=(TestReflection) clazz.newInstance();
// Method[] method=clazz.getMethods();
// for(Method m:method) {
// System.out.println(m.getName());
// }
Method method=clazz.getMethod("setName",String.class);
method.invoke(reflection, "lisi");
System.out.println(reflection.getName());
}
}
内省是java对bean中属性默认的处理方法.可以简单理解为getter/setter方法.
public class IntrospectorDemo {
String abc;
String name;
public static void main(String[] args) throws Exception{
IntrospectorDemo demo = new IntrospectorDemo();
demo.setName("Winter Lau");
//如果不想把父类的属性也列出来的话,
//那getBeanInfo的第二个参数填写父类的信息
BeanInfo bi = Introspector.getBeanInfo(demo.getClass(),Object.class);
PropertyDescriptor[] props = bi.getPropertyDescriptors();
for(int i=0;i<props.length;i++){
props[i].getWriteMethod().invoke(demo, "123");
System.out.println(props[i].getName()+"="+
props[i].getReadMethod().invoke(demo,null));
}
}
public String getAbc() {
return abc;
}
public void setAbc(String str) {
this.abc=str;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
}
可以利用内省获得一个对象中所有的属性,并且可以获取该属性对应的writer与read方法操作该属性.
反射在不重启应用程序的情况下可以通过名字获得Class,内省可以获取Class中的所有属性,并且可以通过默认约定的方法操作属性.