java 继承
文章目录
继承的作用
- 代码重复性高的时候,会造成资源的浪费,可以使用继承的方式设计来避免这个问题
- 降低耦合度,当需求更改,需要修改相同的属性或者方法的时候,只需要修改父类的代码即可,有效降低漏改的可能性(漏改真的很抓狂)
继承的特点
-
子类会把父类所有的属性以及方法继承下来
-
子类除了继承父类的共同属性和方法以外,子类还可以拥有自己特有的方法和属性
-
子类只能继承父类的非private属性,如果要访问private属性,需要提供公共的set和get方法(如果使用的是idea,可以使用alt+insert快速生成)。私有的方法是无法继承的。
class car{ private String name; private String driver; public String getName() { return name; } public void setName(String name) { this.name = name; } public String getDriver() { return driver; } public void setDriver(String driver) { this.driver = driver; } }
-
java只能单继承,而不能多继承(即不能一个类继承于多个类)
继承语法
- 关键字:extends
继承的内存结构
如果创建一个子类的对象,那么在子类的对象的内部会创建一个父类的对象,如果通过子类访问属性的时候,如果子类中没有这个属性,就会到父类中寻找;方法也是一样的。
构造器
构造器的作用
- 构造器是创建对象的时候自动调用的特殊方法,一般用来初始化对象(和python的__init__有点像)
构造器与方法的区别
- 构造器是一种特殊的方法,但是与方法的使用方式和用途却有不同
- 构造器是默认存在的,就算没有写,也是存在构造器的
- 用途:构造器是为了初始化一个实例;而方法是为了执行代码
- 修饰符:构造器不能有以下非访问性质的修饰: abstract, final, native, static, 或者 synchronized。
- 命名:方法一般是一个动词,表示执行一个动作;构造器一般是个名词,因为构造器的名字与类名相同。
- 返回值:构造器一般没有返回值,也不用void修饰
构造器示例:
class Car{
private String name;
private String driver;
public Car(){
System.out.println("父类的构造器被调用了");
}
}
class XueFuLan extends Car{
public XueFuLan(){
System.out.println("子类的构造器被调用了");
}
}
public class homework3 {
public static void main(String[] args) {
XueFuLan newcar = new XueFuLan();
}
}
子类的构造器默认调用父类的构造器
如果你运行了上面的例子,你就会发现:在子类的构造器被调用的之前,会先调用父类的构造器。
super()方法
- super方法是子类的构造器中默认调用父类构造器的方法,一般在子类构造器都是默认使用的,即使代码中没有写出来
- super方法必须放在构造器的第一行
- super()函数调用的是父类的无参构造器或者默认构造器,super(参数1)调用的就是对应的带参数1的父类构造器,相应的,super(参数1,参数2)调用的是父类构造器(参数1,参数2)
- 值得注意的是,当父类存在有参构造器的时候,无参构造器会被覆盖,这个时候如果想调用默认的构造器或者无参构造器,就需要在父类代码中显示的写出来
super关键字
super关键字就是指向父类,this关键字是指向本类的关键字
同样的this也可以调用同类的构造器,调用同类的属性和方法
方法的重写
- 重写(override):子类和父类有相同的方法,但是方法体不同(即除了大括号中的代码块不同,其他全部一样),一般是父类的该方法满足不了子类的需求。
- 重载(overload): ** 同一个类中,有着相同的方法名,但是却有着不同的参数数据类型或者参数个数,这两个方法就称为重载,一般是为了介绍类名的命名资源和提高代码的可读性**
final修饰符
final修饰符修饰的类或者方法不能被子类继承,也不能被改变