9 枚举和注解
文章目录
9.1 自定义类实现枚举
-
实现步骤:
- 构造器私有化
- 本类内部创建一组对象
- 对外暴露对象(通过为对象添加public final static修饰符)
- 提供get方法,但是不提供set方法
-
注意事项和细节:
- 不需要提供setxxx 方法,因为枚举对象值通常为只读
- 枚举对象/属性使用 final + static 共同修饰,实现底层优化
- 枚举对象名通常使用全部大写,常量的命名规范
- 枚举对象根据需要,也可以有多个属性
9.2 enum关键字实现枚举
-
实现步骤:
-
关键字 enum 代替 class
-
行首:常量名(实参列表)
enum Season { SPRING("春天","温暖"),WINTER("冬天","寒冷"); private String name; private String desc; private Season(String name, String desc) { this.name = name; this.desc = desc; }
-
-
注意事项和细节:
-
使用enum 关键字开发一个枚举类时,默认会继承Enum类
-
传统的 public static final Season SPRING = new Season("春天”“温暖”);
简化成 SPRING("春天”,"温暖”),我们必须知道它调用的是哪个构造器
-
如果使用无参构造器 创建 枚举对象,则实参列表和小括号都可以省略
-
多个枚举对象,使用,间隔,最后;结尾
-
枚举对象必须放在枚举类行首
-
-
常用方法:
-
toString:Enum类己经重写过了,返回的是当前对象名子类可以重写该方法,用于返回对象的属性信息
-
name:返回当前对象名(常量名),子类中不能重写
-
ordinal:返回当前对象的位置号,默认从0开始
-
values:返回当前枚举类中所有的常量
-
valueof:将字符串转换成枚举对象,要求字符串必须为已有的常量名,否则报异常
-
compareTo:比较两个枚举常量的编号,做差
public class EnumMethod { public static void main(String[] args) { //使用Season2 枚举类,来演示各种方法 Season2 autumn = Season2.AUTUMN; //输出枚举对象的名字 System.out.println(autumn.name()); //ordinal() 输出的是该枚举对象的次序/编号,从0开始编号 //AUTUMN 枚举对象是第三个,因此输出 2 System.out.println(autumn.ordinal()); //从反编译可以看出 values方法,返回 Season2[] //含有定义的所有枚举对象 Season2[] values = Season2.values(); System.out.println("===遍历取出枚举对象(增强for)===="); for (Season2 season: values) {//增强for循环 System.out.println(season); } //valueOf:将字符串转换成枚举对象,要求字符串必须为已有的常量名,否则报异常 //执行流程 //1. 根据你输入的 "AUTUMN" 到 Season2的枚举对象去查找 //2. 如果找到了,就返回,如果没有找到,就报错 Season2 autumn1 = Season2.valueOf("AUTUMN"); System.out.println("autumn1=" + autumn1); System.out.println(autumn == autumn1); //compareTo:比较两个枚举常量,比较的就是编号 // //1. 就是把 Season2.AUTUMN 枚举对象的编号 和 Season2.SUMMER枚举对象的编号比较 //2. 看看结果 /* public final int compareTo(E o) { return self.ordinal - other.ordinal; } Season2.AUTUMN的编号[2] - Season2.SUMMER的编号[3] */ System.out.println(Season2.AUTUMN.compareTo(Season2.SUMMER)); //补充了一个增强for // int[] nums = {1, 2, 9}; // //普通的for循环 // System.out.println("=====普通的for====="); // for (int i = 0; i < nums.length; i++) { // System.out.println(nums[i]); // } // System.out.println("=====增强的for====="); // //执行流程是 依次从nums数组中取出数据,赋给i, 如果取出完毕,则退出for // for(int i : nums) { // System.out.println("i=" + i); // } } }
-
-
实现接口:
- 使用enum关键字后,就不能再继承其它类了,因为enum会隐式继承Enum,而Java是单继承机制
- 枚举类和普通类一样,可以实现接口:enum 类名 implements 接口1,接口2{}
9.3 JDk内置的基本注解类型
-
基本介绍:
-
注解(Annotation)也被称为元数据(Metadata),用于修饰解释包,类、方法、属性、构造器、局部变量等数据信息
-
和注释一样,注解不影响程序逻辑,但注解可以被编译或运行,相当于嵌入在代码中的补充信息
-
在JavaSE中,注解的使用目的比较简单,例如标记过时的功能,忽略警告等。在JavaEE中注解占据了更重要的角色,例如用来配置应用程序的任何切面,代替java EE旧版本中所有遗留的繁冗代码和XML配置
-
-
基本Annotation介绍:
-
@Override: 限定某个方法,是重写父类方法,该注解只能用于方法
-
@Deprecated:用于表示某个程序元素(类,方法等)己过时
-
@SuppressWarnings:抑制编译器警告
-
9.3.1 @Override
-
基本介绍:
-
@Override 表示指定重写父类的方法(从编译层面验证),如果父类没有方法,则会报错
-
如果没写 @Override 还是会重写父类
-
@Override 只能修饰方法,不能修饰其它类,包,属性等等
-
如果写了@Override 注解,编译器就会去检查该方法是否真的重写了父类的方法,若果没有构成重写则编译错误
-
查看@Override注解源码@Target(ElementType.MRTHOD),说明只能修饰方法
-
@Target 是修饰注解的注解,称为元注解
-
9.3.2 @Deprecated
-
基本介绍:
-
用于表示某个程序元素(类,方法等)己过时
-
可以修饰方法,类,字段,包,参数 等等
-
@Target (value=(CONSTRUCTOR,FIELD,LOCAL_ VARIABLE, METHOD,PACKAGE, PARAMETER, TYPE})
-
@Deprecated 的作用可以做到新旧版本的兼容和过渡
-
9.3.3 @SuppressWarnings
-
基本介绍:
-
抑制编译器警告信息
-
unchecked 是忽略没有检查的警告
-
rawtypes 是忽略没有指定泛型的警告
-
unused 是忽略没有使用某个变量的警告错误
-
@SuppressWarnings可以修饰的程序元素为,查看@Target
-
生成@SupperssWarnings 时,不用背,直接点击左侧的黄色提示,就可以选择(注意可以指定生成的位置)
-