继承
- 减少了代码的冗余,提高了代码复用性
- 便于功能的扩展
- 为之后多态性的使用,提供了前提
继承性的格式
extends 延申、继承、扩充
class A extends B{
}
// A:子类、派生类、subclass
// B:父类、超类、基类、superclass
//一旦子类A继承父类B以后,子类A中就获取父类B中声明的所有属性和方法
-
父类中声明的private的属性或方法,子类继承父类以后,仍认为
获取了父类中私有的结构
。- 因为
封装性的影响
,所以子类并不能直接调用
父类的结构而已。
- 因为
-
子类继承父类以后,还可以声明自己特有的属性或方法:实现功能的拓展。
继承的规定
- Java只支持单继承和多层继承,不允许多继承
- 一个子类只能有一个父类,一个父类可以派生出多个子类(类的单继承性)
- 子类继承父类以后,就获取了直接父类 以及所有间接父类 中声明的属性和方法(多层继承)
- 如果我们没有显式的声明一个类的父类的话,则此类继承与java.lang.Objext类
- 所有的java类(除java.lang.Object类之外)都直接或间接的继承于java.lang.Object类
- 意味着,所有的java类都具有java.lang.Object类声明的功能
方法的重写
override/overwrite
子类继承父类以后,对父类中同名同参数的方法,进行
重置、覆盖
操作重写以后,当创建子类对象以后,通过子类对象调用子父类中同名同参数的方法时,实际执行的是子类重写父类的方法。
-
权限修饰符 返回值类型 方法名 (形参列表) throws 异常的类型{ //方法体 }
-
子类重写的方法的方法名和形参列表与父类被重写的方法方法名和形参相同
-
子类重写的方法的权限修饰符不小于父类被重写的方法权限修饰符
- 但子类不能重写父类中private的方法
-
返回值类型:
- 父类被重写的方法的返回值类型是void,则子类重写的方法的返回值类型只能是void
- 父类被重写的方法的返回值类型是A类型,则子类重写的方法的返回值类型可以是A类或A类的子类
- 父类为Object,则子类可为Object或object的子类(如Stirng)
- 父类被重写的返回值类型是基本的数据类型,则子类重写的方法的返回值类型必须是相同的基本数据类型
- 父类为double,则子类必须也是double
-
子类重写的方法抛出的异常类型不大于被重写的方法抛出的异常类型(具体在异常)
子类和父类中同名同参数的方法要么都声明为非static的(考虑重写),要么都声明为static的(不是重写、static无法重写)
super关键字
可以用来调用父类的:属性、方法、构造器
- 在子类的方法或构造器中。通过使用
super.属性
或super.方法
的方式,显式的调用父类中声明的属性或方法。但是,通常情况下,我们习惯省略"super." - 当子类和父类中定义了同名的属性时,我们要想在子类中调用父类中声明的属性,则必须显式的使用
super.属性
的方法,表明调用的是父类中声明的属性 - 当子类重写了父类的方法以后,我们想在子类的方法中调用父类中被重写的方法时,则必须显式的使用
super.方法
的方式,表明调用的是父类中被重写的方法。
调用父类构造器
super(形参列表)
必须声明在子类构造器的首行
- 在类的构造器中,针对于
this(形参列表)
或super(形参列表)
只能二选一,不能同时出现 - 在构造器的首行,没有显式的声明
this(形参列表)
或super(形参列表)
,则默认调用的是父类中空参的构造器 - 在类的多个构造器中,至少有一个类的构造器中使用了
super(形参列表)
,调用了父类中的构造器
子类对象实例化过程
虽然创建子类对象时,调用了父类的构造器,但是
自始至终就创建过一个对象,即为new的子类对象
结果上看
- 子类继承父类以后就获取了父类中声明的属性或方法。创建子类的对象,在堆空间中,就
会加载所有父类中声明的属性
过程上看
- 当我们通过子类的构造器创建子类对象时,我们一定会直接或间接的调用其父类的构造器,进而调用父类的父类的构造器…,
直到调用了java.lang.Object类中空参的构造器为止
。正因为加载过所有的父类的构造器,所以才看到内存中有父类中的结构,子类对象才可以考虑进行调用