当前位置 博文首页 > @王某人:java----反射与内省
?????JAVA反射机制是在运行状态中,获取任意一个类的结构 , 创建对象 , 得到方法,执行方法 , 属性
也可以是私有封装的, 这种在运行状态动态获取信息以及动态调用对象方法的功能被称为java语
言的反射机制。
?????Java类加载器(Java Classloader)是Java运行时环境(Java Runtime Environment)的一
部分, 负责动态加载Java类到Java虚拟机的内存空间中。
?????java默认有三种类加载器:
??????????BootstrapClassLoader、ExtensionClassLoader、App ClassLoader。
??????????BootstrapClassLoader(引导启动类加载器):
???????????????嵌在JVM内核中的加载器,该加载器是用C++语言写的,主要负载加载
???????????????JAVA_HOME/lib下的类库,引 导启动类加载器无法被应用程序直接使用。
??????????ExtensionClassLoader(扩展类加载器):
???????????????ExtensionClassLoader是用JAVA编写,且它的父类加载器是Bootstrap。 是由
???????????????sun.misc.Launcher$ExtClassLoader实现的,主要加载JAVA_HOME/lib/ext目录中
???????????????的类 库。它的父加载器是BootstrapClassLoader
??????????App ClassLoader(应用类加载器):
???????????????App ClassLoader是应用程序类加载器,负责加载应用程序classpath目录下的所有
???????????????jar和class文 件。它的父加载器为Ext ClassLoader
类通常是按需加载,即第一次使用该类时才加载。由于有了类加载器,Java运行时系统不需
要知道文件与 文件系统。
双亲委派模型:如果一个类加载器收到了一个类加载请求,它不会自己去尝试加载这个类,
而是把这个请求 转交给父类加载器去完成。每一个层次的类加载器都是如此。因此所有的类
加载请求都应该传递到最顶层的启动类加载器中,只有到父类加载器反馈自己无法完成这个
加载请求(在它的搜索范围没有找到这个类) 时,子类加载器才会尝试自己去加载。委派的
好处就是避免有些类被重复加载。
?????给项目添加resource root目录:创建一个文件夹,将类型改为resource root类型
?????通过类加载器加载资源文件:
?????默认加载的是src路径下的文件,但是当项目存在resource root目录时,就变为了加载
?????resource root下的文件了。
?????类名.class.getClassLoader.getResourceAsStream(“文件名”);得到一个输入流
?????再将输入流转换为字符读取流,读取文件中的内容
?????要想了解一个类,必须先要获取到该类的字节码文件对象. 在Java中,每一个字节码文件,被
夹在到内存后,都存在一个对应的Class类型的对象
??????????通过class对象 获取一个类的构造方法
?????常用方法:
??????????newInstance(Object… para)
???????????????调用这个构造方法, 把对应的对象创建出来 参数: 是一个Object类型可变参数, 传递
???????????????的参数顺序 必须匹配构造方法中形式参数列表的顺序!
??????????setAccessible(boolean flag)
???????????????如果flag为true 则表示忽略访问权限检查 !(可以访问任何权限的方法)
?????通过class对象 获取一个类的方法
?????invoke(Object o,Object… para) :
??????????调用方法 ,
???????????????参数1. 要调用方法的对象
???????????????参数2. 要传递的参数列表
?????getName()
??????????获取方法的方法名称
?????setAccessible(boolean flag)
??????????如果flag为true 则表示忽略访问权限检查 !(可以访问任何权限的方法)
通过class对象 获取一个类的属性
常用方法:
?????获取类/属性/方法的全部注解对象
??????????Annotation[] annotations01 = Class/Field/Method.getAnnotations();
??????????for (Annotation annotation : annotations01) {
???????????????System.out.println(annotation);
??????????}
?????根据类型获取类/属性/方法的注解对象
?????注解类型 对象名 = (注解类型) c.getAnnotation(注解类型.class);
?????基于反射 , java所提供的一套应用到JavaBean的API
?????一个定义在包中的类 ,
??????????拥有无参构造器
??????????所有属性私有,
??????????所有属性提供get/set方法
??????????实现了序列化接口 这种类,
??????????我们称其为 bean类 .
?????Java提供了一套java.beans包的api , 对于反射的操作, 进行了封装 !
?????获取Bean类信息
?????方法:
?????????? BeanInfo bi = Introspector.getBeanInfo(Class cls)
???????????????通过传入的类信息, 得到这个Bean类的封装对象 .
??????????BeanInfo
??????????常用的方法:
???????????????ProertyDescriptor[] pds = bi.getPropertyDescriptors():
????????????????????获取bean类的 get/set方法 数组
???????????????MethodDescriptor
???????????????常用方法:
????????????????????1. Method getReadMethod();
????????????????????????? 获取一个get方法
????????????????????2. Method getWriteMethod();
?????????????????????????获取一个set方法
???????????????有可能返回null 注意 ,加判断
??????????注意:如果封装的是Boolean类型的数据,获得方法是isFlag()