Java SE 枚举,注解,增强for循环
Java SE 进阶
1.Enum
- 枚举对象名通常使用全部大写,常量的命名规范
- 构造器私有化
- 本类内部创建一组对象
- 对外暴露对象(通过为对象添加 public final static 修饰符)
- 可以提供 get 方法,但是不要提供 set
//1. 将构造器私有化,目的防止 直接new
//2. 去掉setXxx方法,防止属性被修改
//3. 再Season内部,直接创建固定的对象
//4. 优化,可以加入 final 修饰符
//演示自定义枚举实现
class Season{
private String name;
private String desc;//描述
//定义了四个对象
public static final Season SPRING = new Season("春天", "温暖");
public static final Season WINTER = new Season("冬天", "寒冷");
public static final Season AUTUMN = new Season("夏天", "炎热");
public static final Season SUMMER = new Season("秋天", "凉爽");
//调用
System.out.println(Season.AUTUMN);
-
当我们使用enum关键字开发一个枚举类时,默认会继承Enum类而且是一个final类
//1.使用关键字 enum 代替 class //2.常量名(实参列表) //3.如果有多个常量对象,使用 , 间隔即可 //4.如果使用 enum 来实现枚举,要求将定义常量对象,写在前面 //5.如果我们使用的是无参构造器,常见常量对象,则可以省略 () SPRING("春天", "温暖"),WINTER("冬天", "寒冷"), AUTUMN("夏天", "炎热"),SUMMER("秋天", "凉爽"),What;
-
枚举对象必须放在枚举类的首行
-
演示 Enum 类的各种方法的使用
Season2 autumn = Season2.AUTUMN; toString:Enum类已经重写过了,返回的是当前对象名,子类可以重写该方法,用于返回对象的属性信息 //输出枚举对象的名字 System.out.println(autumn.name()); //ordinal() 输出的是该枚举对象的次序/编号,从0开始编号 //AUTUMN 枚举对象是第三个,因此输出 2 System.out.println(autumn.ordinal()); //从反编译可以看出 values方法,返回 Season2[] //含有定义的所有枚举对象 Season2[] values = Season2.values(); for (Season2 season : values){ //增强for循环 System.out.println(season); } //valueOf:将字符串转换成枚举对象,要求字符串必须为已有的常量名,负责异常 //执行流程 //1. 根据你输入的 "AUTUMN" 到 Season2 的枚举对象去查找 //2. 如果找到了,就返回,如果没有找到,就报错 Season2 autumn1 = Season2.valueOf("AUTUMN"); System.out.println("autumn1=" + autumn1); //compareTo:比较两个枚举常量,比较的就是编号 //return Season2.AUTUMN 的编号[2] - Season2.SUMMER 的编号[3] System.out.println(Season2.AUTUMN.compareTo(Season2.SUMMER));
-
补充了一个for循环
int[] nums = {1,2,4,5,6}; for (int i = 0; i < nums.length; i++) { System.out.println(nums[i]); } System.out.println("=============="); //执行流程是 依次从nums数组中取出数据,赋给i,如果去除完毕,则退出for循环 for (int i : nums){ System.out.println(i); }
-
使用了enum关键字后,就不能在继承其他类了,因为enum会隐式的继承Enum,而Java是单继承机制
-
枚举类和普通类一样,可以实现接口 形式如下:
enum 类名 implements 接口1,接口2{}
2.注解
@Override
// 1.@Override 注解放在fly方法上,表示子类的fly方法重写了父类的fly方法
// 2.如果你写了@Override注解,编译器就会去检查该方法是否是真的重写了父类 的方法,如果重写了,则编译通过,如果没有构成重写,则编译错误
/*
//@Override 的定义
// 如果发现 @interface 表示一个 注解类
@Target(ElementType.METHOD)
@Retention(RetentionPolicy.SOURCE)
public @interface Override {
}
*/
@Deprecated
//1. @Deprecated 修饰某个元素,表示该元素已经过时
//2. 即不在推荐使用,但是仍然可以使用
//3. 可以修饰方法, 类, 字段, 包, 参数 等等
//4. @Deprecated 可以做版本升级过度使用
@SuppressWarnings
//1. 当我们不希望看到这些警告的时候,可以使用 SuppressWarnings 注解来抑制警告信息
//2. 在{""}中,可以写入你希望抑制(不显示)警告信息
@SuppressWarnings({""})
//3. 关于 SuppressWarnings 作用范围是和你放置的位置相关
// 比如 @SuppressWarnings 放置在 main 方法,那么抑制警告的范围就是 main
// 通常我们可以放置在具体的语句,方法,类
静态部分的代码,只会随着类的加载会执行一次