Java实例化过程及synchronized问题

问题1:实例化一个对象时,因为会实例化父类,是不是代表如果一个类的父类越多,那它在堆中占的空间越多?
问题2:A a = new B()的时候(B extends A)在子类override父类的synchronized方法的时候,如果在子类中调用父类方法,此时是锁住的是子类对象,为什么不会是父类?

富国沪深
浏览 505回答 3
3回答

心有法竹

两个问题源于一个错误认识,实例化一个对象只产生一个对象,只是实例化时候会先调用父构造器,那也是以未来返回这个对象的身份调用,并不会产生一个父类对象,占空间大小取决于类属性有多少了,既然只有一个对象,谈何锁住父类对象呢

扬帆大鱼

实例化一个对象时只会使用invokespecial指令调用父类的<init>方法,也就是构造器,不会实例化父类对象,在子类中调用父类方法,使用synchronized修饰方法锁住的是当前对象也就是子类。

翻阅古今

要看你继承的父类有多少成员变量和方法,子类实例化的时候分配的内存是子类和父类成员属性和方法的总和,跟父类的个数无关,而第二个问题对于synchronized这样的对象锁,谁调用了synchronized方法就是锁住谁,也就是this对象
打开App,查看更多内容
随时随地看视频慕课网APP

相关分类

Java