Java基础类总结(枚举类和注解)

1. 枚举类的使用

1.1 枚举类简单介绍

理解内容

🍀理解枚举类:

类的对象只能是有限个,是确定的。称这样的类为枚举类
  例如:  季节分为:春天,夏天,秋天,冬天
               线程状态分为:创建、就绪、运行、阻塞、死亡(结束) …

🍀说明:

当需要定义一组常量时,建议使用枚举类
若枚举只有一个对象, 则可以作为一种单例模式的实现方式。

1.2枚举类的定义方式

比较重要

1.2.1 实现方式一:1.自定义枚举类

🍀说明:

实现时,和平时定义的类差别很小,具体的不同体现在需要把类的每一个对象直接声明在枚举类的内部,使用public static final修饰对象

🍀实现步骤:

1.声明Season对象的属性:使用private final修饰
2.私有化类的构造器,并给对象属性赋值
3.提供当前枚举类的多个对象,使用public static final修饰
4.根据自己需要,自定义方法

🍀实现代码展示:
自定义类Code:

class Season{

    //1.声明Season对象的属性:使用private final修饰
    private final String seasonName;
    private final String seasonDesc;

    //2.私有化类的构造器,并给对象属性赋值
    private Season(String seasonName,String seasonDesc){
        this.seasonName = seasonName;
        this.seasonDesc = seasonDesc;
    }

    //3.提供当前枚举类的多个对象,使用public static final修饰
    public static final Season SPRING = new Season("春天","春暖花开");
    public static final Season SUMMER = new Season("夏天","夏日炎炎");
    public static final Season AUTUMN = new Season("秋天","秋高气爽");
    public static final Season WINTER = new Season("冬天","冰天雪地");

    //4.其他的要求,自定义

    public String getSeasonName() {
        return seasonName;
    }

    public String getSeasonDesc() {
        return seasonDesc;
    }

    @Override
    public String toString() {
        return "Season{" +
                "seasonName='" + seasonName + '\'' +
                ", seasonDesc='" + seasonDesc + '\'' +
                '}';
    }
}

Main():

public class SeasonTest {

    public static void main(String[] args) {

        //直接使用类名调用对象
        Season spring = Season.SPRING;
        System.out.println(spring);
    }
}

1.2.2 实现方式二:使用enum关键字定义枚举类

🍀说明:

和自定义枚举类的区别:需要先提供当前枚举类的对象,声明的格式如下所示,最大的变化时,在声明对象时还可以把声明对象时的共同部分去掉,简化为如下情况:

只需要说明对象名以及属性即可

	SPRING("春天","春暖花开"),
    SUMMER("夏天","夏日炎炎"),
    AUTUMN("秋天","秋高气爽"),
    WINTER("冬天","冰天雪地");

🍀实现步骤:

1.提供当前枚举类的多个对象,中间使用",“隔开,最后一个使用”;"
2.声明Season对象的属性:使用private final修饰
3.私有化类的构造器,并给对象属性赋值
4.其他的要求,自定义

🍀实现代码样例展示:

enum Season1{
    //1.提供当前枚举类的多个对象,中间使用","隔开,最后一个使用";"
    SPRING("春天","春暖花开"){
        @Override
        public void show() {
            System.out.println("这是春天,适合春游.");
        }
    },
    SUMMER("夏天","夏日炎炎"){
        @Override
        public void show() {
            System.out.println("这是夏天,适合钓鱼.");
        }
    },
    AUTUMN("秋天","秋高气爽"){
        @Override
        public void show() {
            System.out.println("这是秋天,适合游玩.");
        }
    },
    WINTER("冬天","冰天雪地"){
        @Override
        public void show() {
            System.out.println("这是冬天,适合滑雪.");
        }
    };
    //1.声明Season对象的属性:使用private final修饰
    private final String seasonName;
    private final String seasonDesc;

    //2.私有化类的构造器,并给对象属性赋值
    private Season1(String seasonName, String seasonDesc){
        this.seasonName = seasonName;
        this.seasonDesc = seasonDesc;
    }



    //4.其他的要求,自定义

    public String getSeasonName() {
        return seasonName;
    }

    public String getSeasonDesc() {
        return seasonDesc;
    }

    @Override
    public String toString() {
        return "Season1{" +
                "seasonName='" + seasonName + '\'' +
                ", seasonDesc='" + seasonDesc + '\'' +
                '}';
    }
}

main():

public class SeasonTest1 {

    public static void main(String[] args) {
        Season1 spring = Season1.SPRING;
        System.out.println(spring);

        System.out.println("**************************");

        //values()方法:返回枚举类型的对象数组。
        Season1[] values = Season1.values();
        for (int i = 0; i < values.length; i++) {
            System.out.println(values[i]);
            values[i].show();
        }

        System.out.println("**************************");

        //valueOf(),返回枚举类中对象名是ObjName的对象。如不是,抛出异常IllegalArgumentException。
        Season1 winter = Season1.valueOf("WINTER");
        System.out.println(winter);

    }
}

🍀提示:
1.定义的枚举类,默认继承于java.long.Enum类
2.Enum的主要方法
① values()方法:返回枚举类型的对象数组。该方法可以很方便地遍历所有的枚举值。
② valueOf(String str):可以把一个字符串转为对应的枚举类对象。要求字符串必须是枚举类对象的“名字”。如不是,会有运行时异常:IllegalArgumentException。
③ toString():返回当前枚举类对象常量的名称

2. 注解

2.1 注解的简单介绍

了解内容
在以后学习到框架在详细了解

🍀概述:

Annotation 其实就是代码里的特殊标记, 这些标记可以在编译, 类加载, 运行时被读取, 并执行相应的处理。通过使用 Annotation, 程序员可以在不改变原有逻辑的情况下, 在源文件中嵌入一些补充信息。代码分析工具、开发工具和部署工具可以通过这些补充信息进行验证或者进行部署。使用@+注解类型的方式定义

平时在继承时,需要重写父类中的方法时@Override就是使用了注解的形式

2.2 Annotation的使用

🍀Annotation使用的三种类型:
示例①:生成文档时的相关注解
可以定义作者、包名、模块名、描述等等
例如:

@BelongsProject: com.java.li
@BelongsPackage: day13.com.it.java1
@Author: Administrator
@CreateTime: 2022-05-09 20:41
@Description: 注解的使用

示例②:在编译时进行格式检查(JDK内置的三个基本注解)
@Override: 限定重写父类方法, 该注解只能用于方法,如果重写的方法名不一致,@override会直接报错
@Deprecated: 用于表示所修饰的元素(类, 方法等)已过时。通常是因为所修饰的结构危险或存在更好的选择

🍀使用样例:
对于父类,自定义walk(),和eat()方法:

class Person{

    private String name;
    private int age;

    public Person() {
    }

    public Person(String name, int age) {
        this.name = name;
        this.age = age;
    }

    public void walk(){
        System.out.println("人走路");
    }

    public void eat(){
        System.out.println("人吃饭");
    }

    @Override
    public String toString() {
        return "Person{" +
                "name='" + name + '\'' +
                ", age=" + age +
                '}';
    }

    public String getName() {
        return name;
    }

    public int getAge() {
        return age;
    }
}

对于子类,重写父类的方法

class Student extends Person {

    public Student(String name, int age) {
        super(name, age);
    }

    @Override
    public void walk() {
        System.out.println("学生走路");
    }
}

示例③:跟踪代码依赖性,实现替代配置文件功能
@SuppressWarnings: 抑制编译器警告

2.3 自定义 Annotation的使用

了解内容

🍀1.实现自定义注解的步骤:

①注解声明为:@interface
②内部定义成员,通常使用value表示
③可以指定成员的默认值,使用default定义
④如果自定义注解没有成员,表明是一个标识作用

🍀2.实现样例

@Repeatable(MyAntations.class)//可实现重复注解
@Target({TYPE, FIELD, METHOD, PARAMETER, CONSTRUCTOR, LOCAL_VARIABLE})
@Retention(RetentionPolicy.SOURCE)
public @interface MyAnnotation {
    String value() default "hi";//提供的默认值
}

2.4 jdk提供的四种元注解

🍀说明:

①Retention 只能用于修饰一个 Annotation 定义, 用于指定该 Annotation 的生命周期,SOURCE(在源文件有效)/CLASS(在编译时有效)/RUNTIME(在运行时有效)
②Target用于修饰 Annotation 定义, 用于指定被修饰的 Annotation 能用于修饰哪些程序元素
以下两种并不常用,可以忽略
③Documented用于指定被该元 Annotation 修饰的 Annotation 类将被javadoc 工具提取成文档。
④Inherited被它修饰的 Annotation 将具有继承性。

🍀实现样例

@Repeatable(MyAntations.class)//可实现重复注解
@Target({TYPE, FIELD, METHOD, PARAMETER, CONSTRUCTOR, LOCAL_VARIABLE})
@Retention(RetentionPolicy.SOURCE)
public @interface MyAnnotation {
    String value() default "hi";//提供的默认值
}
  • 14
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 9
    评论
评论 9
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

皮皮皮皮皮皮皮卡乒

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

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

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

打赏作者

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

抵扣说明:

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

余额充值