1、类名.class
说明:JVM将使用类装载器,将类装入内存(前提是:类还没有装入内存),不对类做类的初始化工作。返回类的Class的对象。
3、实例对象o.getClass()
运行结果:
.class>>>class reflect.ClassTest
静态参数的初始化
class.forName>>>class reflect.ClassTest
非静态参数的初始化
构造方法
getClass>>>class reflect.ClassTest
运行结果:
Father类的构造方法:
Father.class:class reflect.Father
getClass():class reflect.Son
从结果看来,getClass()获取的是实际运行的类的字节码,它不一定是当前类的Class,有可能是当前类的子类的Class,具体是哪个类的Class,需要根据实际运行的类来确定,new的是哪个类,getClass()获取的就是哪个类的Class;而类.class获取得到的Class永远只能是该类的Class。
说明:JVM将使用类装载器,将类装入内存(前提是:类还没有装入内存),不对类做类的初始化工作。返回类的Class的对象。
2、Class.forName("类名字符串")(注:类名字符串是包名+类名)
说明:装入类,并做类的静态初始化,返回Class的对象。3、实例对象o.getClass()
说明:对类进行静态初始化、非静态初始化;返回引用o运行时真正所指的对象(因为子对象的引用可能会赋给父对象的引用变量中)所属的类的Class的对象。
.getClass()是动态的,其余是静态的。
.class和class.forName()只能返回类内field的默认值,getClass可以返回当前对象中field的最新值。
Class.forName() 返回的是一个类,.newInstance() 后才创建一个对象,Class.forName()的作用是要求JVM查找并加载指定的类,也就是说JVM会执行该类的。
package reflect;
public class ClassTest {
public ClassTest() {
System.out.println("构造方法");
}
static {
System.out.println("静态参数的初始化");
}
{
System.out.println("非静态参数的初始化");
}
}
package reflect;
public class Demo {
public static void main(String[] args) throws Exception {
// .class
System.out.println(".class>>>" + ClassTest.class);
// class.forName
Class clazz = Class.forName("reflect.ClassTest");
System.out.println("class.forName>>>" + clazz);
// getClass
System.out.println("getClass>>>" + new ClassTest().getClass());
}
}
运行结果:
.class>>>class reflect.ClassTest
静态参数的初始化
class.forName>>>class reflect.ClassTest
非静态参数的初始化
构造方法
getClass>>>class reflect.ClassTest
三种方法生成的Class对象是一样的,且程序只执行了一次“静态参数的初始化”(Class.forName装入类时做类的静态初始化)。静态方法是在类加载的时候初始化的,非静态方法是在new对象的时候初始化的。由此可见此三种方法生成的是同一个Class对象。
通过代码来看下类名.class和getClass()的区别:
package reflect;
public class Father {
public Father() {
System.out.println("Father类的构造方法:");
System.out.println("Father.class:" + Father.class);
System.out.println("getClass():" + getClass());
}
}
package reflect;
public class Son extends Father {
}
package reflect;
public class Demo {
public static void main(String[] args) throws Exception {
new Son();
}
}
运行结果:
Father类的构造方法:
Father.class:class reflect.Father
getClass():class reflect.Son
从结果看来,getClass()获取的是实际运行的类的字节码,它不一定是当前类的Class,有可能是当前类的子类的Class,具体是哪个类的Class,需要根据实际运行的类来确定,new的是哪个类,getClass()获取的就是哪个类的Class;而类.class获取得到的Class永远只能是该类的Class。