B、反射机制的应用:
生成动态代理,面向切片编程(在调用方法的前后各加栈帧).
C、反射机制的原理:
1、首先明确的概念: 一切皆对象—-类也是对象.
2、然后知道类中的内容 :modifier constructor field method.
3、其次明白加载: 当Animal.class在硬盘中时,是一个文件,当载入到内存中,可以认为是一个对象,是java.lang.class的对象.
当运行程序时,实例化时产生Animal.class对象,这两个对象有什么区别?
如下图,上面的Animal.class对象是java.lang.class的对象;下面的对象是Animal.class实例化产生的对象
4、当Animal.class载入到JVM中,JVM是怎么识别Animal.class中含有的方法,成员变量,构造方法等内容?
如下图, Animal.class实例化对象中成员变量 毛色 =红色;
加载到内存的时候,毛色=null,是在实例化的时候毛色被赋值为红色.
Animal.class中毛色这个属性对于java.lang.class来说,是Field的一个属性值, 毛色对于java.lang.class来说也是一个对象.这也是反射机制动态获取信息,以及动态调用对象方法的原因.
下图是Java.lang.class 中的方法
在java.lang.class中,毛色是Field的一个属性值,Animal中所有的方法,成员变量,构造器,修饰符都是按照java.lang.class中的标准去写的,否则会在编译的时候报错
D、放射机制简单实例代码
public class _14_ReflectTest07{ public static void main(String[] args) throws Exception{ //1.获取类 Class c = Class.forName("_12_CustomerService"); //获取某个特定的方法 //通过:方法名+形参列表 Method m = c.getDeclaredMethod("login",String.class,String.class); //通过反射机制执行login方法. Object o = c.newInstance(); //调用o对象的m方法,传递"admin""123"参数,方法的执行结果是retValue Object retValue = m.invoke(o, "admin","123"); System.out.println(retValue); //true }} public class _12_CustomerService{ //登录 public boolean login(String name,String pwd){ if("admin".equals(name) && "123".equals(pwd)){ return true; } return false; } //退出 public void logout(){ System.out.println("系统已安全退出!"); }}