A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 沉湎码海 中级黑马   /  2017-2-12 10:18  /  1214 人查看  /  3 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

我们先看这个图,然后结合图来理解:
下面解释:
为什么要在子类构造方法中,调用父类的构造方法??? 这是为什么在子类的构造方法中使用super(参数列表)的原因:
因为:
  根据继承机制,子类自动拥有父类的成员,在创建子类对象的时候,子类对象在内存中划分区域存储子类对象空间中,划分两个区域,一个区域留给自己的自定义的成员变量,一个区域留给自己的父类成员变量。
即:父类的成员变量是跟随子类对象进入堆内存的。
所以:
                当子类继承了父类,它就拥有了父类的成员,而对于父类成员的初始化,必须通过调用父类的构造方法来实现。
               
        这也是为什么要使用super(参数列表);的原因。
       
       
最好结合:子类对象的内存图来理解。

super.png (212.12 KB, 下载次数: 8)

super.png

3 个回复

倒序浏览
回复 使用道具 举报
不错,赞一个。
回复 使用道具 举报
楼主分析的不错,学到了
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马