java基础——继承

继承

有相同的属性,相同的方法就叫相同的特征
提取出来变成一个类

可以使得子类具有父类的属性和方法,子类可以增加
public class 子类名extends 父类名()

必须使用关键字才能使用父类的方法。

继承的好处

提高代码的复用性
提高代码的维护性,如果需要修改,修改一处即可

弊端

当父类发生变化子类也需要变化
is a 苹果和水果,猫和动物,猫和狗

继承中变量的访问特点

在方法中使用变量时,现在方法内部找,再在内部找,再去父类找。
如果都没有就报错

super关键字

关键字的用法和this关键字的用法相似
this:代表本类对象的引用
super:代表父类存储空间的标识

继承中构造方法的访问特点

子类中所有的构造方法默认都会访问父类中无参的构造方法。
因为子类会继承父类中的数据,可能还会使用父类的数据。所以,子类初始化之前,一定要先完成父类数据的初始化。
每一个子类构造方法的第一条语句默认都是:super()

如果父类中没有无参构造方法,只有带参构造方法
通过使用super关键字去显示的调用父类的带参构造方法
在父类中自己提供一个无参构造方法
推荐:自己给出无参构造方法

继承中成员方法的访问特点

通过子类对象访问一个方法
子类成员范围找
父类成员范围找
找不到就报错

向上转型

父类的引用变量可以指向子类,因为子类拥有父类的全部功能,相当于把子类抽象成了一个父类来使用。这种被称为向上转型(upcasting)。

向下转型

不能把父类变为子类,即不能用子类引用变量指向一个父类实例,除非该父类引用变量指向了一个子类实例。
因为子类功能比父类多,多的功能无法凭空变出来。

为了避免向下转型出错,Java提供了instanceof操作符,可以先判断一个实例究竟是不是某种类型:

Person p = new Person();
System.out.println(p instanceof Person); // true
System.out.println(p instanceof Student); // false

Student s = new Student();
System.out.println(s instanceof Person); // true
System.out.println(s instanceof Student); // true

Student n = null;
System.out.println(n instanceof Student); // false

instanceof实际上判断一个变量所指向的实例是否是指定类型,或者这个类型的子类。如果一个引用变量为null,那么对任何instanceof的判断都为false。

从Java 14开始,判断instanceof后,可以直接转型为指定变量,避免再次强制转型。例如,对于以下代码:

Object obj = "hello";
if (obj instanceof String) {
    String s = (String) obj;
    System.out.println(s.toUpperCase());
}

可以改写如下:
// instanceof variable:
public class Main {
    public static void main(String[] args) {
        Object obj = "hello";
        if (obj instanceof String s) {
            // 可以直接使用变量s:
            System.out.println(s.toUpperCase());
        }
    }
}

阻止继承

正常情况下,只要某个class没有final修饰符,那么任何类都可以从该class继承。
从Java 15开始,允许使用sealed修饰class,并通过permits明确写出能够从该class继承的子类名称。
例如,定义一个Shape类:

public sealed class Shape permits Rect, Circle, Triangle {
    ...
}

上述Shape类就是一个sealed类,它只允许指定的3个类继承它。如果写:

public final class Rect extends Shape {...}

是没问题的,因为Rect出现在Shape的permits列表中。但是,如果定义一个Ellipse就会报错:

public final class Ellipse extends Shape {...}
// Compile error: class is not allowed to extend sealed class: Shape

原因是Ellipse并未出现在Shape的permits列表中。这种sealed类主要用于一些框架,防止继承被滥用。

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值