主要解决共性抽取的问题,子类继承了父类内容
特点:
- 子类有自己的内容
- 子类继承父类内容
格式:public class 子类 extends 父类 {}
1 继承中成员变量的访问特点
- 父类对象只能使用父类成员变量,子类可直接调用父类变量
- 出现同名变量,优先访问使用对象中的变量
- 间接通过成员方法访问成员变量,方法属于(定义于)谁,就调用谁的变量,没有则向上找
2 区分子、父类中的重名内容
2.1 成员变量
- 局部变量
直接写成员变量名
- 本类的成员变量
this.成员变量
- 父类的成员变量
super.成员变量
2.2 成员方法
- 创建的对象是谁,就优先用谁,没有则向上找,绝不会向下(子类)找
3 子类覆盖重写父类方法
Override与Overload不同
特点:
- 创建的是子类对象,则优先用子类方法
- 方法名称,参数列表都相同
@Override
写在前面用于检测是不是有效的覆盖重写,最好加上- 返回值必须小于等于父类方法的返回值范围
object类(java.lang.Object)是所有公共类最高父类 - 子类方法的权限必须大于等于父类方法的权限修饰符(public>protected>(default)>private)
default不是关键字,而是留空(什么都不写)
以上大于等于绝大多数情况都保持相等
设计原则:已经投入使用的类尽量不要修改,而是定义一个新类继承并重写其方法
4 继承中构造方法的访问特点
- 子类构造方法中有一个默认的
super()
调用
public class Son extends Father {
String str = "Son";
public Son() {
super(); // 默认的调用父类无参构造方法
System.out.println("调用子类构造方法");
}
- 只有子类构造方法可以通过
super
关键字来调用父类重载构造
super
的父类构造调动,必须是子类构造方法的第一个语句,不能一个子类构造多次调用super
构造
5 super和this
5.1 super关键字的三中用法
- 子类成员方法访问父类成员变量
- 子类成员方法访问父类成员方法
- 子类成员方法访问父类构造方法
public class Son extends Father {
String str = "Son";
public Son() {
super(25); // 默认的调用父类无参构造方法 // 父类构造方法
System.out.println("调用子类构造方法");
}
public void methodSon() {
System.out.println(super.str); // 父类成员变量
super.methodFather(); // 父类成员方法
}
}
5.2 this关键字的三种用法
- 在本类成员方法中访问本类成员变量
- 访问本类成员方法
- 在本类构造方法中访问本类另一个构造方法(构造方法的重载调用)
第三种用法注意:
this()
调用方法也必须是构造方法中的第一个也是唯一的语句
super()
和this()
两种构造调用不能同时使用,各自唯一
5.3 super和this内存图
6 java中继承的特点
- 单继承:一个类的直接父类唯一不能
B extends A, B
- 多级继承
- 父类可以有多个子类
7 抽象
概念
- 抽象方法:父类中广泛定义(方法体不确定)的方法,在其子类中具体实现
- 抽象类
格式:
- 抽象方法
abstract void method();
不加大括号,所在的类必须是抽象类 - 抽象类:
abstract class 类名
class前加abstract
使用
- 不能直接创建new抽象对象,必须用一个子类继承抽象父类,创建子类对象使用
- 子类必须覆盖重写抽象类中所有的抽象方法.
注意
- 抽象类不能创建对象
- 抽象类可以有构造方法,是给子类创建对象时,初始化父类成员使用的
public Cat() {
super(); // 调用抽象父类构造方法
System.out.println("子类构造方法执行");
}
- 抽象类不一定有抽象方法,没有抽象方法的抽象类在设计模式:适配器模式中有用
- 抽象类子类必须覆盖抽象类所有抽象方法,除非该子类也是抽象类