Person.class方法与person.getClass()方法字节码文件相同?及Class.forName(“xxx“)方法三者区别?

Person.class与person.getClass()不是同一个对象

注意:这里是存在父子关系情况下,并非Person person = new Person()情况,Person.class与person.getClass()肯定是相同的字节码文件毋庸置疑

ManInterface接口及其实现子类Person

interface ManInterface {
    void doWork();
}

class Person implements ManInterface {
    private String name;
	public Person() {}

    public Person(String name) {this.name = name;}

    @Override
    public void doWork() {
        System.out.println(this.name + "doWorking...");
    }
}

测试类

public class DynamicTest {
    public static void main(String[] args) {
        ManInterface person = new Person("pp");
        System.out.println(person.getClass()==ManInterface.class);
        System.out.println(person.getClass().getName());
        System.out.println(ManInterface.class.getName());
    }
}

运行结果:

false
Person
ManInterface

总结:可以发现完全是不一样的,getClass()方法是一个实例方法,由对象调用,它返回的是一个运行时对象的类信息ManInterface person = new Person("pp");这段代码运行时的对象是person对象,所以通过getName()获取到的路径是Person类信息,而不是接口ManInterface信息,

然后我们ManInterface.class就是此类Clazz接口的基本信息,两者的区别还是很大的,在给个列子看的更清楚什么是运行对象的类信息

List<String> list = new ArrayList<>();
System.out.println(list.getClass());

Object str = new String();
System.out.println(str.getClass());

结果:

class java.util.ArrayList
class java.lang.String

 

Person.class、person.getClass()、Class.forName(“com.cn.Person.class”)区别?

创建Person

public class Person {
    static {
        System.out.println("Person 静态方法");
    }
    {
        System.out.println("Person 构造代码块");
    }
    public Person() {
        System.out.println("Person 无参构造方法");
    }
}

测试类

public class MainTest {

    public static void main(String[] args) throws Exception {
       // Class<Person> personClass = Person.class; //运行结果:无输出内容
        //Class.forName("com.cn.Person"); //运行结果: Person 静态方法
        Class<? extends Person> aClass = new Person().getClass();//运行结果: Person 静态方法 Person 构造代码块 Person 无参构造方法
    }
}

总结:

  • Person.classJVM将使用类装载器,将类装入内存(前提是:类还没有装入内存),不做类的初始化工作,返回Class的对象
  • Class.forName("com.cn.Person")(注:类名字符串是包名+类名) 说明:装入类,并做类的静态初始化,返回Class的对象
  • person.getClass() 说明:对类进行静态初始化、非静态初始化;返回引用运行时真正所指的对象(因为:子对象的引用可能会赋给父对象的引用变量中)所属的类的Class的对象

       根据结果发现,三种生成Class对象一样的。且程序只打印一次静态方法。我们知道,静态方法初始化,是在加载类的时候初始化。非静态方法,是new类实例对象时加载。因此,这段程序说明,三种方式生成Class对象,其实只有一个Class对象。

       在生成Class对象时,首先判断内存中是否已经加载过。 当我们编写一个java类时,JVM会帮我们编译成Class对象,存放在同名.class文件中。在运行时,当需要生成这个类的对象时,JVM会检查此类是否已经装载到内存中。若没有装载,则把.class文件装入到内存。若已装载,则根据Class文件生成实例对象。
 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

魔道不误砍柴功

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值