3.29~3.30学习总结

刷题情况:

蓝桥杯刷题:

Java学习情况:

抽象类:如果将子类中抽取的共性行为(方法),子类的执行不一样的时候

(通俗一点来说,就是无法找到一个万能的方法体供子类使用,但这个行为是一样(例如:狗吃骨头,羊吃艹,这个行为是一致的,但父类的方法体不能够万能的描述这俩个动物的吃的行为,也就是确定不了方法体)将这个方法定义为抽象方法。

当一个类中存在了抽象方法的时候,那这个类一定是抽象类,用abstract修饰。

但是抽象类中允许存在普通方法。总结一下就是:存在抽象方法一定是抽象类,抽象类不一定有抽象方法。

抽象类不允许创建实例,也就是不允许创建对象。

抽象类的子类:要么重写抽象类的所有方法,要么这个类继续为抽象类。

抽象类中允许存在抽象方法。

接口和抽象类的区别:

意义上的不同:

接口体现的是一种规范,类似于整个系统的总纲。

抽象类体现的是一种模板式设计,抽象类可以被当作系统实现产品的中间产品,可以参与完成多个不同的最终产品。

语法上的不同

接口里面只允许存在抽象方法,静态方法和默认方法(default),不能为普通方法提供方法实现,

而抽象类中可以存在普通方法。

接口里面只能定义静态常量(public static final)

而抽象类可以有普通成员变量,也可以有静态常量。

接口没有构造方法。

抽象类有构造方法。

接口不能包含初始化块。

抽象类可以包含初始化块。

内部类:简单来说就是在一个类里面的类

成员内部类:一个类中和成员变量处于同一位置的类

非静态内部类:特殊的成员内部类(有static修饰)

静态内部类:特殊的成员内部类(有static修饰)

局部内部类(定义于方法中的类)(用处不大)

匿名内部类(重点):

内部类可以直接访问外部类的成员变量(无论是非私有还是私有)(类比,成员变量可以访问成员变量(无论是私有还是非私有))但是外部类不能直接访问内部类,需要创建内部类的对象才可以访问。

外部类静态成员不能访问非静态的内部类

非静态内部类里不允许定义静态成员(静态方法,静态初始化块,静态变量);

但是静态内部类里面可以有非静态内部类和静态内部类

这里补充static的一个知识,static的作用是把类成员变成和类相关,而不是实例相关,static修饰的成员属于整个类,而不是单个对象,而外部类的上一级程序单元是包,所以不可以使用static修饰,内部类可以使用static修饰,使得内部类变得和外部类相关。

静态内部类不能访问外部类的实例成员,只能访问外部类的静态成员。

匿名内部类:

匿名内部类不能是抽象类,因为匿名内部类在创建的时候就创建了匿名内部类的对象,因此不允许将匿名内部类定义成抽象类(抽象类不能创建实例,只能作为父类去派生子类)

匿名内部类不能定义构造方法,因为匿名内部类没有类名,所以无法定义构造方法,但可以定义初始化块,可以通过实例初始块来完成构造方法需要完成的事情。

最常用的创建匿名内部类的方式是需要创建某个接口类型的对象。

创建匿名内部类的时候,必须实现接口或抽象父类里的所有抽象方法,(如果有需要,也可以重写父类中的普通方法)

枚举类:

package exerse;

public enum SeasonEnum {
    Spring,Summer,Fall,Winter;
}

枚举常量序数从0开始;

枚举类默认继承了java.lang.Enum类,而不是object类,因此枚举类不能显式继承其他父类,

使用enum类定义,非抽象的枚举类会默认使用final修饰,因此枚举类不能派生子类。

枚举类的构造器只能使用private访问控制符,如果省略了构造器(构造方法)的访问控制符,那么默认使用private修饰,如果强制指定访问控制符,那么只能指定private控制符,

!!!注意:枚举类的实例必须在枚举类的第一行显式列出,否则这个枚举类永远都不能产生实例。这些实例,系统会自动添加静态常量的修饰符(public static final)。

枚举类默认提供了一个values()方法,该方法可以很方便的遍历所有的枚举值。、

代码演示:

package exerse;

public class EnumTest {
    public void judge(SeasonEnum s){
        switch (s)
        {
            case Spring -> System.out.println("春天");
            case Summer -> System.out.println("夏天");
            case Fall -> System.out.println("秋天");
            case Winter -> System.out.println("冬天");
        }
    }
    public static void main(String[] args) {
        for (SeasonEnum s:SeasonEnum.values() ){
            System.out.println(s);
        }
        EnumTest p=new EnumTest();
        p.judge(SeasonEnum.Spring);
    }
}

枚举类和普通的类区别不大,差别在于,创建枚举类对象不能随意创建,创建的实例只能是枚举值。列出枚举值的时候,可以不用显示调用构造器,不用使用new关键字,就可以船舰枚举类对象。

在枚举类中添加私有构造方法,列出枚举值的时候传入参数:好处:更加安全,成员变量都不可随意改变。

枚举类和普通类一样,也可以实现一个或者多个接口,实现接口和普通类一致,

不是所有的枚举类都为final修饰,当枚举类的内部存在抽象方法的时候,这个枚举类就是用abstract所修饰,不是使用final修饰。这个时候存在派生子类。

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

卡卡卡卡罗特

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值