首先理解RTTI:Run Time Type Identification ,运行时识别类型信息。
Class对象:它包含了与类有关的信息,事实上,Class对象就是用来创建类的所有的"常规"对象的。类是程序的一部分,每个类都有一个Class对象。换言之,每当编写并且编译了一个新类,就会产生一个Class对象(更恰当地说,是被保存在一个同名的.class文件中)。为了生成这个类的对象,运行这个程序的Java虚拟机(JVM)将使用被称为"类加载器"的子系统。
所有类都是在对其第一次使用时,动态加载到JVM中。当程序创建第一个对类的静态成员的引用时,就会加载这个类。这个证明构造器也是累的静态方法,即使构造器之前没有使用static关键字。因此,使用new操作符创建类的新对象也会被当做对类的静态成员的引用。
因此,Java程序在它开始运行之前并非被完全加载,其各个部分是在必需时才会加载的。
类加载器首先检查这个类的Class对象是否已经加载。如果尚未加载,默认的类加载器就会根据类名查找.class文件。在这个类的字节码被加载时,它们会接受验证,保证其没有被破坏,并且不包含不良Java代码。
加载类的方法:Class.forName(String className).其中参数是全名,即包含包名。此时会去查找.class文件,然后JVM加载该类。如果找不到.class文件,就会报ClassNotFoundException.加载的过程当中,就会执行对应的静态方法。
实际上加载类的过程:
1.加载,这是由类加载器执行的。该步骤将查找字节码(通常在classpath所指定的路径中查找,但这并非是必需的)。并从这些字节码中创建一个Class对象。
2.链接,在链接阶段将验证类的字节码,为静态域分配存储空间。并且如果必需的话,将解析这个类创建的对其他类的所有引用。
3.初始化,如果该类具有超类(父类),则对其初始化,执行静态初始化和静态初始化块。
其中初始化被延迟了对静态方法(构造器隐式地是静态)或者非常数据静态域进行首次引用时才执行:
obj.class得到一个Class对象。但是不会对该类进行初始化。
Class.newInstance()方法可以得到一个Class对象,但要求是该类有默认的无参构造器。
反射:即可以在运行时加载类,读取程序在编译阶段不能获取类的信息。借助Field,Class,Method等类来获取。比如修改该类型的字段,构造方法,方法等。。。。即在运行时获取类的信息。