1.变量
如果子类中出现非私有的同名成员变量时:1.子类要访问本类中的变量,用this。2.子类要访问父类中的同名变量时,用super
super的使用和this的使用几乎一致。
this代表的是本类对象的引用。
super代表的是父类对象的引用。
class Person
{
int num=4 ;
}
class student extends Person
{
void show()
{
system.out.println(super.num);
}
}
2.函数(覆盖或重写)
当子类出现和父类一模一样的函数时
当子类对象调用该函数,会运行子类函数的内容,
如同父类的汗数被覆盖一样
这样的情况是函数的另一种特性:重写或覆盖
概念:
但子类继承父类,沿袭了父类的功能到子类中,但子类虽具备该功能,但是功能的内容却和父类不一致,这时,没有必要定义性功能,而是使用覆盖功能,保留父类的功能定义,并重写功能内容。
用处:复写源码和扩展
注意:
1.子类覆盖父类,必须保证子类的权限大于等于父类权限,才可以覆盖,否则编译失败,前面如果没写权限的话默认有一个权限大于private,小于public
但父类定义了private就不能重写
2.静态只能覆盖静态
3重载只看同名函数参数列表
重写子类父类方法要一模一样(返回值类型和有无返回值要一模一样)
3.子类和父类中的构造函数
super()语句调用的是父类的构造函数 super。show()调用父类的方法
特点:
发现在对子类对象初始化时,父类的构造函数也会运行,那是因为子类的构造函数在第一行默认有一句隐式的语句super();它调用的是父类的空参数的构造函数,而且子类中必须有一个构造函数中有super();但父类的空参数的构造函数被定义为不是空参数的构造函数时,子类中就必须定义super(参数)
为啥子类一定要访问父类中的构造函数?
因为父列中的数据子类可以直接获取,所以子类对象在建立时,需要先查看父类是如何对这些数据进行初始化的,所以子类在对象初始化时要先访问一下父类中的构造函数,如果要访问父类中年指定的构造函数,可以同过手动定义super语句的方式来指定。
super语句一定要在子类的构造函数的第一行。
(子类的实例化的过程)
结论:
1.子类的所有的构造函数都会饿默认访问父类空参数的构造函数。因为子类每一个构造函数内的第一行都有一句隐式的super()
2.当父类中没有空参数的构造函数时,子类必须手动通过super()形式来指定要访问的构造函数
3.当然子类的构造函数的第一行也可以手动定义this语句来访问本类中的构造函数。子类中至少会有一个构造函数会访问父类中的构造函数
4.父类中你的构造函数也会有super();
因为父列也会extends java中的object
为啥同一个构造函数中不能同时拥有this和super
因为他们都要定义在第一行
为啥都在第一行
因为为了初始化对象