0x00:继承概述
继承是面向对象的三大特征之一。可以使得子类具有父类的属性和方法,还可以在子类中重新定义,追加属性和方法。
0x01:继承的格式:
格式:public class 子类名 extends 父类名{}
父类,也被称为超类、基类。
子类,也被称为派生类。
0x03:继承的好处和弊端
继承的好处:
- 提高了代码的复用性(多个类相同的成员可以放到同一个类中)
- 提高了代码的维护性(如果多个方法的代码需要修改,修改一处即可)
继承的弊端:
- 继承让类与类之间产生了关系,类的耦合性增强了,当父类发生变化时,子类实现也不得不发生变化,削弱了子类的独立性
什么时候使用继承呢:
- 继承体现的关系: is a
- 假设法: 我有两个类A 和 B,如果他们满足A是B一种,或者B是A的一种,这个时候就可以考虑使用继承来体现
0x04:super
super 关键字的用法 和this 关键字的用法相似
- this:代表本类对象的引用
- super:代表父类存储空间的标识(可以理解为父类对象引用)
| 关键字 | 访问成员变量 | 访问构造方法 | 访问成员方法 |
| —- | —- | —- | —- |
| this | this.成员变量
访问本类成员变量 | this(…) 访问本类构造方法 | this.成员方法(….)
访问本类成员方法 | | super | super.成员变量
访问父类成员变量 | super(…) 访问父类构造方法 | super.成员方法(….)
访问父类成员方法 |
(1)继承中变量的访问特点
在子类中访问一个变量
①:子类局部范围找
②:子类成员范围找
③:父类成员范围找
如果都没有的话就报错
(2)继承中构造方法的访问特点:
子类中的构造方法默认访问父类中无参的构造方法
子类会继承父类中的数据, 所以,子类初始化之前,一定要先完成父类的初始化
每一个子类构造方法的第一条语句默认都是super()
如果父类中没有无参构造方法,只有带参构造方法,该怎么办呢?
- 通过使用super关键字去显示的调用父类的带参构造方法
- 在父类中自己提供一个无参构造方法
推荐: 自己给出无参构造方法
例子:
父类
package Test;
public class Fu {
// public Fu(){
// System.out.println("fu类中无参构造方法被调用");
// }
public Fu(int age){
System.out.println("fu类中带参构造方法被调用");
}
}
子类
package Test;
public class Zi extends Fu{
public Zi() {
super(20);
System.out.println("zi类中无参构造方法被调用");
}
public Zi(int age){
super(20);
System.out.println("zi类中带参构造方法被调用");
}
}
demo:
package Test;
public class Demo {
public static void main(String[] args) {
Zi z = new Zi();
Zi z2 = new Zi(20);
}
}
(3)继承中成员方法的访问特点:
通过子类对象访问一个方法:
- 子类成员范围找
- 父类成员范围找
- 如果没有就报错
0x05: 方法重写
方法重写概述: 子类中出现了和父类中一模一样的方法
当子类需要父类的功能,而功能主体子类有自己特有内容时, 可以重写父类中的方法,这样,即沿袭了父类的功能,又定义了子类特有的内容。
@Override 是一个注解,可以帮助我们检查重写方法的重要性
方法重写注意事项:
- 私有方法不能被重写(父类私有成员子类是不能继承的)
- 子类方法访问权限不能更低(public > 默认 > 私有)
0x06:Java中继承的注意事项
①:Java中类只支持单继承,不支持多继承
②:Java中类支持多层继承,一层,一层的继承