1、RTTI
运行时,识别一个对象的类型。
2、Class对象
- 每个类都有一个Class 对象,用于运行时类型发现。
- Class.forName() 是对类的加载,返回class 对象的引用。
- Class类的方法:printInfo newInstance getInterfaces getSuperclass
3、类字面常量
- .class,当使用类字面常量创建对class对象的引用时,不会自动地初始化该Class对象。初始化延迟到对静态方法或者非常数静态域进行首次引用。
Class init = init.class;
- 在初始化对象时需要准备三个工作:
- 加载:类加载器查找字节码,并从字节码中创建Class对象。
- 链接:验证类中的字节码,为静态域分配存储空间,并且必需的话,将解析这个类创建对其他类的所有引用。
- 初始化:执行静态初始化器和静态初始化块,如果该类具有超类,则对其初始化。
4、泛型的Class引用
Class<?> 优越于平凡的Class
Class<? extends classA> 将类型限制一个范围内,该类型的任何子类型
5、类型检查
- 使用instanceof,java中对于向上转型编译器进行处理,不需要进行显示的类型转换;而对于向下转型则需要显示类型转换。在c++中并没有对RTTI的要求,只是简单告诉编译器将这个对象作为一个新的类型处理。
if(x instanceof Dog)
Dog.class.isInstance(x)
6、反射
RTTI与反射的区别:.class文件在编译时和运行时获取。
class类与java.lang.reflect类库一起对反射的概念进行了支持,该类库包含了Field、Method以及Construtor类。
7、动态代理
动态地创建代理并动态地处理对所代理方法的调用。
动态代理是代理模式的一种实现,在jdk中Proxy对此进行良好的支持。
Proxy.newProxyInstance()可以创建动态代理,需要三个参数,一个是类加载器,一个是希望该代理实现的接口列表,以及InvocationHandler接口的一个实现。