从零开始的"E"世界(J2SE)

JavaNote4

1.面向对象–继承

1.1 继承的概述
  • 多个类中存在相同属性和行为时,将这些内容抽取到
    单独一个类中,那么多个类无需再定义这些属性和行
    为,只要继承单独的那个类即可。
  • 多个类可以称为子类,单独这个类称为父类或者超
    类。
  • 子类可以直接访问父类中的非私有的属性和行为。
  • 通过 extends 关键字让类与类之间产生继承关系。

  • 注意:要访问父类的私有属性必须用共有的set和get方法.
    子类不能降低父类继承过来的方法的权限

简单说:对于一个继承体系的使用,查阅顶层父类中的内容,创建最底层子类的对
象。


1.2 继承的特点(好处)
  • 提高了代码的复用性。
  • 让类与类之间产生了关系,提供了另一个特征多态的前提。

  • Java只支持单继承,不支持多继承。
    一个类只能有一个父类,不可以有多个父类。

  • Java支持多层继承(继承体系)


1.3 super关键字
  • super和this的用法相同
  • this代表是本类类型的对象引用
  • super代表是子类所属的父类中的内存空间引用
  • 当子父类出现同名成员时,可以用super进行区分
  • 子类要调用父类构造函数时,可以使用super语
    句。(必须放在第一行)

注意

  • 子类中所有的构造函数都会默认访问父类中的空参数的构造函数,因为每一个子类构造内第一行都有默认的语句 super();
  • 如果父类中没有空参数的构造函数,那么子类的构造函数内,必须通过 super 语句指定要访问的父类中的构造函数。
  • 如果子类构造函数中用 this 来指定调用子类自己的构造函数,那么被调用的构造
    函数也一样会访问父类中的构造函数。
  • super()和 this()不能同时出现的构造函数中。

1.4 函数覆盖
  • 子类中出现与父类一模一样的方法时,会出现覆盖操作,也称为重写或者复写。
  • 父类中的私有方法不可以被覆盖。
  • 在子类覆盖方法中,继续使用被覆盖的方法可以通过super.函数名获取。
  • 覆盖注意事项

    • 子类覆盖父类时,必须要保证,子类方法的权限必须大于等于父类方法权限可以实现继承。否则,编译失败
    • 覆盖时,要么都静态,要么都不静态。 (静态只能覆盖静态,或者被静态覆盖)
  • 覆盖的应用:
    当子类需要父类的功能,而功能主体子类有自己特有内容时,可以复写
    父类中的方法,这样,即沿袭了父类的功能,又定义了子类特有的内
    容。

  • 继承的一个弊端:打破了封装性。对于一些类,或者类中功能,是需要被继承,或者复写的。

1.4 final关键字
  • final 特点
    • final可以修饰类,方法,变量。
    • final修饰的类不可以被继承。
    • final修饰的方法不可以被覆盖。
    • final修饰的变量是一个常量。只能被赋值一次。
  • 内部类只能访问被final修饰的局部变量。

2.抽象类(abstract)

2.1 抽象类概述
  • 抽象:不具体,看不明白。抽象类表象体现。
  • 在不断抽取过程中,将共性内容中的方法声明抽取,但是方法不一样,没有抽取,这时抽取到的方法,并不具体,需要被指定关键字 abstract 所标示,声明为抽象方法。
  • 抽象方法所在类一定要标示为抽象类,也就是说该类需要被 abstract 关键字所修饰。

2.2 抽象类的特点
  • 抽象方法只能定义在抽象类中,抽象类和抽象方法必须由 abstract 关键字修饰(可以描述类和方法,不可以描述变量)。
  • 抽象方法只定义方法声明,并不定义方法实现。
  • 抽象类不可以被创建对象(实例化)。
  • 只有通过子类继承抽象类并覆盖了抽象类中的所有抽象方法后,该子类才可以实例化。否则,该子类还是一个抽象类。

2.2 抽象类的细节(相关问题)
  • 1:抽象类中是否有构造函数?有,用于给子类对象进行初始化。
  • 2:抽象类中是否可以定义非抽象方法?
    可以。其实,抽象类和一般类没有太大的区别,都是在描述事物,只不过抽象类在
    描述事物时,有些功能不具体。所以抽象类和一般类在定义上,都是需要定义属性和行为的。只不过,比一般类多了一个抽象函数。而且比一般类少了一个创建对象的部分。
  • 3:抽象关键字 abstract 和哪些不可以共存?final , private , static
  • 4:抽象类中可不可以不定义抽象方法?可以。抽象方法目的仅仅为了不让该类创建对象

2.3 模板方法设计模式

解决的问题:当功能内部一部分实现时确定,一部分实现是不确定的。这时可以把不确定的部分暴露出去,让子类去实现。

abstract class GetTime{
    public final void getTime(){ //此功能如果不需要复写,可加 final 限定
        long start = System.currentTimeMillis();
        code(); //不确定的功能部分,提取出来,通过抽象方法实现
        long end = System.currentTimeMillis();
        System.out.println("毫秒是:"+(end-start));
    } 
    public abstract void code(); //抽象不确定的功能,让子类复写实现
} 
class SubDemo extends GetTime{
    public void code(){ //子类复写功能方法
        for(int y=0; y<1000; y++){
            System.out.println("y");
        }
    }
}

最后附上Java学习网址

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值