【Java笔记】19 枚举和注解

一、枚举

1.1 简介

枚举是一组常量的集合

1.2 实现方式

  1. 自定义类实现枚举
  • 构造器私有化
  • 本类内部创建一组对象
  • 对外暴露对象:public final static修饰符
  • 可以提供get方法,不提供set方法
  1. public class Enumeration02 {
  2. public static void main(String[] args) {
  3. System.out.println(Season.AUTUMN);
  4. }
  5. }
  6. // 自定义枚举
  7. class Season{
  8. private String name;
  9. private String desc;
  10. // 定义4个对象
  11. public static final Season SPRING = new Season("春天","温暖");
  12. public static final Season WINTER = new Season("冬天", "寒冷");
  13. public static final Season AUTUMN = new Season("秋天", "凉爽");
  14. public static final Season SUMMER = new Season("夏天", "炎热");
  15. // 1. 将构造器私有化,防止直接new对象
  16. // 2. 不要setXXX方法,防止属性被修改
  17. // 3. 在类内部创建固定的对象
  18. // 4. 优化,加final(final和static往往搭配使用,效率更高,不会导致类加载)
  19. private Season(String name, String desc) {
  20. this.name = name;
  21. this.desc = desc;
  22. }
  23. @Override
  24. public String toString() {
  25. return "Season{" +
  26. "name='" + name + '\'' +
  27. ", desc='" + desc + '\'' +
  28. '}';
  29. }
  30. }
  1. enum关键字实现枚举
  1. public class Enumeration03 {
  2. public static void main(String[] args) {
  3. System.out.println(Season.AUTUMN);
  4. }
  5. }
  6. enum Season2{
  7. // 1. 使用关键字enum替代class
  8. // 2. 常量名(实参列表)简化public static final
  9. // 3. 多个常量(对象),逗号间隔
  10. // 4. 使用enum实现枚举,将定义常量对象写在前面
  11. SPRING("春天","温暖"),WINTER("冬天","寒冷");
  12. private String name;
  13. private String desc;
  14. // 1. 将构造器私有化,防止直接new对象
  15. // 2. 不要setXXX方法,防止属性被修改
  16. // 3. 在类内部创建固定的对象
  17. // 4. 优化,加final(final和static往往搭配使用,效率更高,不会导致类加载)
  18. private Season2(String name, String desc) {
  19. this.name = name;
  20. this.desc = desc;
  21. }
  22. @Override
  23. public String toString() {
  24. return "Season{" +
  25. "name='" + name + '\'' +
  26. ", desc='" + desc + '\'' +
  27. '}';
  28. }
  29. }
  • 使用enum写一个枚举类,默认会继承Enum类,而且是一个final类
  • 使用无参构造器创建枚举对象,则实参列表和小括号都可以省略
  • 多个枚举对象时,使用逗号间隔,分号结尾
  • 枚举对象必须放在枚举类的行首

1.3 enum类常用方法

  • toString 子类可以重写该方法用于返回对象的属性信息
  • name 返回当前对象名(常量名),子类中不能重写
  • ordinal 返回当前对象的位置号,默认从0开始
  • values 返回当前枚举类中的所有常量
  • valueOf 将字符串转换成枚举对象
  • compareTo 比较两个枚举常量,相等返回0
  1. public class EnumMethod {
  2. public static void main(String[] args) {
  3. Season2 spring = Season2.SPRING;
  4. // 输出枚举对象名字
  5. System.out.println(spring.name());
  6. // ordinal()输出的时该枚举对象的次序,从0开始编号
  7. System.out.println(spring.ordinal());
  8. // values方法,返回Season2数组,包括定义的所有枚举对象
  9. Season2[] values = Season2.values();
  10. for (Season2 season: values) {
  11. System.out.println(season);
  12. }
  13. // valueOf()将字符串转化成枚举对象,字符串必须为已有常量名
  14. Season2 spring1 = Season2.valueOf("SPRING");
  15. System.out.println("spring1=" + spring1); // spring1=Season{name='春天', desc='温暖'}
  16. System.out.println(spring == spring1); // true
  17. // compareTo:比较两个枚举常量,比较的是编号
  18. /*
  19. 比较的是编号 两个枚举常量相等就返回0
  20. public final int compareTo(E o) {
  21. Enum<?> other = (Enum<?>)o;
  22. Enum<E> self = this;
  23. if (self.getClass() != other.getClass() && // optimization
  24. self.getDeclaringClass() != other.getDeclaringClass())
  25. throw new ClassCastException();
  26. return self.ordinal - other.ordinal;
  27. }
  28. */
  29. System.out.println(Season2.SPRING.compareTo(Season2.WINTER)); // -1
  30. }
  31. }

1.4 enum实现接口

使用 enum 关键字后,就不能再继承其它类了,因为 enum 会隐式继承 Enum

枚举类和普通类一样,可以实现接口

  1. public class EnumDetail {
  2. public static void main(String[] args) {
  3. Music.CLASSIC.playing();
  4. }
  5. }
  6. interface IPlaying {
  7. public void playing();
  8. }
  9. enum Music implements IPlaying {
  10. CLASSIC;
  11. @Override
  12. public void playing() {
  13. System.out.println("playing");
  14. }
  15. }

二、注解 Annotation

2.1 基本介绍

  • 注解也被称为元数据,用于解释包、类、方法、属性、构造器、局部变量等数据信息
  • 注解可以被编译或运行,补充信息
  • 把Annotation当成一个修饰符,前面加@

2.2 三个基本的Annotation

  1. @Override 用于方法,重写父类方法

    1. public class Override_ {
    2. public static void main(String[] args) {
    3. }
    4. }
    5. class Father{
    6. public void fly(){
    7. System.out.println("Father fly");
    8. }
    9. }
    10. class Son extends Father{
    11. // 写了@Override编译器就会检查该方法是否真的重写了
    12. /*
    13. 源码 @interface 表示一个注解类
    14. @Target(ElementType.METHOD) // 表示只能修饰方法
    15. @Retention(RetentionPolicy.SOURCE)
    16. public @interface Override {
    17. }
    18. */
    19. @Override
    20. public void fly(){
    21. System.out.println("Son fly");
    22. }
    23. }
  2. @Deprecated 表示某个程序元素(类、方法等)已过时

8(6YME1{W)NYURXHQDO2SW4.png

  1. @SuppressWarning 抑制编译器警告
    1. public class SuppressWarnings_ {
    2. // 不希望看到某些警告 在{""} 中,可以写入你希望抑制(不显示)警告信息
    3. //可以指定的警告类型有
    4. // all,抑制所有警告
    5. // boxing,抑制与封装/拆装作业相关的警告
    6. // cast,抑制与强制转型作业相关的警告
    7. // dep-ann,抑制与淘汰注释相关的警告
    8. // deprecation,抑制与淘汰的相关警告
    9. // fallthrough,抑制与 switch 陈述式中遗漏 break 相关的警告
    10. // finally,抑制与未传回 finally 区块相关的警告
    11. // hiding,抑制与隐藏变数的区域变数相关的警告
    12. // incomplete-switch,抑制与 switch 陈述式(enum case)中遗漏项目相关的警告
    13. // javadoc,抑制与 javadoc 相关的警告
    14. // nls,抑制与非 nls 字串文字相关的警告
    15. // null,抑制与空值分析相关的警告
    16. // rawtypes,抑制与使用 raw 类型相关的警告
    17. // resource,抑制与使用 Closeable 类型的资源相关的警告
    18. // restriction,抑制与使用不建议或禁止参照相关的警告
    19. // serial,抑制与可序列化的类别遗漏 serialVersionUID 栏位相关的警告
    20. // static-access,抑制与静态存取不正确相关的警告
    21. // static-method,抑制与可能宣告为 static 的方法相关的警告
    22. // super,抑制与置换方法相关但不含 super 呼叫的警告
    23. // synthetic-access,抑制与内部类别的存取未最佳化相关的警告
    24. // sync-override,抑制因为置换同步方法而遗漏同步化的警告
    25. // unchecked,抑制与未检查的作业相关的警告
    26. // unqualified-field-access,抑制与栏位存取不合格相关的警告
    27. // unused,抑制与未用的程式码及停用的程式码相关的警告
    28. // SuppressWarnings 作用范围和放置的位置相关
    29. // 比如 @SuppressWarnings 放置在 main 方法,那么抑制警告的范围就是 main
    30. }

2.3 元注解

JDK的元注解

Retention //指定注解的作用范围,三种 SOURCE,CLASS,RUNTIME

Target // 指定注解可以在哪些地方使用

Documented //指定该注解是否会在 javadoc 体现

Inherited //子类会继承父类注解