Java之父、子实例的内存控制

本文深入探讨Java中的继承机制,包括方法覆盖与实例变量隐藏的区别、子类实例在内存中的存储方式以及如何通过super关键字访问父类变量和方法等内容。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1继承成员变量和继承方法的区别
如果在子类重写了父类方法,意味着子类里定义的方法会彻底的覆盖父类里同名的方法,系统将不可能把父类里的方法转移到子类中。对于实例变量则不存在这样的现象,即使子类中定义了与父类完全同名的实例变量,这个实例变量依然不可能覆盖父类中定义的实例变量。
因为继承成员变量和继承方法之存在这样的差别,该实例变量的值取决于声明该变量时的类型;
当通过该变量来调用它所引用的对象的方法时,该方法行为取决于它所实际引用的对象的类型
2内存中的子类实例
程序允许某个方法通过return this;返回调用该方法的Java对象,但不允许直接 return super;甚至不允许直接将super当成一个引用变量使用。
super关键字本身并没有引用任何对象,它甚至不能被当成一个真正的引用变量使用。
子类方法不能直接使用return super;但使用return this;返回调用该方法的对象是允许的;
程序不允许直接把super当成变量使用。
对于父子对象在内存中存储有了准确的结论:当程序创意一个子类对象时,系统不仅会为该类中定义的实例变量分配内存,也会为其父类中定义的所有实例变量分配内存,即使子类定义了与父类中同名实例变量。当系统创建一个Java对象的时候,如果该Java类有两个父类(一个直接父类A,一个间接父类B),假设A类中定义了2个实例变量,B类中定义了3个实例变量,当前类中定义了2个实例变量,那这个Java对象将会保存2+3+2个实例变量。
如果在子类中定义了与父类同名的实例变量,子类中定义的变量会隐藏父类中定义的变量。注意不是完全覆盖,因此系统中为创建子类对象时,依然会为父类中定义的,隐藏的变量分配内存空间。
为了在子类方法中访问父类中定义的,隐藏的实例变量,或者为了在子类方法中调用父类中定义的,被覆盖的方法,可以通过super.作为限定来修饰这些实例变量和实例方法。
访问哪个实例变量由声明该变量的类型决定。
3父子类的类变量
这里再次强调,类变量属于类本身,实例变量则属于Java对象。类变量在初始化类阶段就完成了初始化,而实力变量则在对象初始化阶段初始化。
类变量本质上属于类本身。通常不会涉及父子实例变量那样复杂的情形,但由于Java通过对象来访问类变量,因此也可以使用super.作为限定来访问父类中定义的类变量。
如果需要访问父类中的类变量,则有两种方式:
直接使用父类本身的类名作为主调来访问类变量
使用super.作为限定访问父类类变量。
通常建议第一种方式来访问父类类变量,因为类变量属于类本身,使用类名作为主调来访问父类类变量能够保持代码可读性。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值