关于继承的内存本质变化。
看如下代码:
package com.kxy.extend_;
class GrandPa{
String name="大头爷爷";
String hobby="旅游";
}
class Father extends GrandPa{
String name="大头爸爸";
int age=45;
}
class Son extends Father{
String name="大头儿子";
}
public class ExtendsTheory {
public static void main(String[] args) {
Son son=new Son();
System.out.println(son.name);
}
}
看完以上代码之后。
让我们来分析一下,内存变化情况:
1.内存栈里通过main方法读取到,son对象的引用并且在内存堆里实例化对象,首先在从基类Object出发,通过构造器自带的super()完成每一级的初始化。也就是从基类逐次加载到Son类。
2.加载完毕后,就从Jvm内存堆里分配空间。拿本案例来讲,先从爷爷类开始分配内存,由于两个属性都是字符串应用类型的值,故它需要先到常量池里存储好相应的地址,那么它的属性就指向了常量池里的地址,在下次调用这些值的时候,其实质是通过取出常量池里的地址。爷爷类的地址开辟完成之后,就同样的开辟爸爸类、儿子类的内存。
3.上述内容完成后,堆里的抽象类son分配一个最后的地址,而此时栈里把Son类的对象son的引用指向了这个地址0X11。至此,就是Son son=new Son();的内存变化情况。下图是内存布局图。
本博客中的案例摘取于【零基础 快速学Java】韩顺平 零基础30天学会Java_哔哩哔哩_bilibili 继承本质详解。如有小伙伴不懂的可以去学习一下。