覆盖不会删除父类中的方法,而是对子类的实例隐藏,暂时不使用,而super可以调用这些隐藏的方法

Java核心卷;有些人认为 super 与 this 引用是类似的概念, 实际上,这样比较并不太恰当。这是因为 super 不是一个对象的引用, 不能将 super 赋给另一个对象变量, 它只是一个指示编译器调用超类方法的特殊关键字

我为什么会觉得父类中的this应该是父类本身对象的this(这是错误的想法),子类实例化的过程会先去执行父类的构造函数,这个大家肯定都是知道,但我过去错误的以为,执行了父类的构造函数意味着新建了父类的对象.......,所以我才会觉得父类中的this指的应该是父类的对象引用,但其实调用父类构造器并不是创建父类的对象,而是子类在创建对象的过程中,“借用” 父类构造器创建子类的对象。由于子类继承了父类,内存中不但会划分子类的变量空间,也会将子类的所有父类的成员变量也划分内存空间,所以可以使用super去访问他们。

在国内查阅相关super关键字介绍,大多也都是说子对象里有父对象。但是这种说法是错误的,有两个例子可以证明其错误:

1. super不能赋给另一个对象变量

2. 抽象类不能创建对象,但是如果一个类的父类是抽象类,仍然可以通过super调用其父类的方法

super.test()只是在说调用父类中的test方法,并不是说用父类对象来调用父类的test方法。

你此时是使用子对象来调用父类的test方法的,所以父类的test方法里面的this指的是调用该方法的子对象。