对于每一个class来说,在其被JVM加载后,都会生成一个对应的Class对象,这个对象是Java.lang.Class类的实例。
Class类该类中提供了访问类中的构造器、方法、属性变量、注释等等一系列属性的方法
获取类构造器Declared关键字指忽略访问权限
- getConstructor(Class>…parameterTypes)
- getConstructors()
- getDeclaredConstructor(Class>…parameterTypes)
- getDeclaredConstructors()
- getMethod(String name, Class>…parameterTypes)
- getMethods()
- getDeclaredMethod(String name, Class>…parameterTypes)
- getDeclaredMethods()
- getField(String name)
- getFields()
- getDeclaredField(String name)
- getDeclaredFields()
- A getAnnotation(Class annotationClass)
- Annotation[] getAnnotations()
Java中的类由类加载器加载至内存中,其中类加载器根据继承关系,分别为
- 根加载器 BootStrap ClassLoader
- 拓展加载器 Extension ClassLoader
- 系统类加载器 System ClassLoader
- 用户类加载器
- 全盘负责:当某一个类是由指定的类加载器加载的,那么该类所依赖的其他类也有该类加载器负责。
- 父类委托:先让父类加载器加载该Class,若无法加载再由本类加载器加载
- 缓存机制:所有已经被加载过的类都会被保存在缓存中,当程序需要某个类时,会首先在缓存中寻找该类,若找不到则会从class二进制文件中加载类并将其转换至Class对象并存入缓存区。
Tomcat为什么要打破双亲委派(父类委托)类加载机制链接
动态代理动态代理的功能是为在面向切片编程(AOP)的过程中,为接口实现动态实现。
基于Proxy类和InvocaHandler来实现接口的动态代理
- 首先需要定义一个interface,里面有一些方法
- 定义一个InvocaHandler接口的实现类,需要实现invoke()方法
- 基于Proxy.newProxyInstance(ClassLoader loader, Class>[] interfaces, InvocationHandler h)方法获取接口的代理对象
- 基于代理对象运行接口中的方法(其实是调用了invoke方法)



