1.历史:
枚举是JDK1.5版本新增的特性(泛型、For-each等如今被广泛应用的特性也是由JDK1.5时所新增的),另外到了JDK1.6后switch语句支持枚举类型。
2.枚举的语法解析:
1.最最最简单版
1
2
3
|
public enum ColorEnum { RED,BLUE,GREEN } |
2.现在我们在枚举类中增加自己的字段以及一些辅助方法,代码如下:
public enum ColorEnum { RED("red","红色"),GREEN("green","绿色"),BLUE("blue","蓝色"); //防止字段值被修改,增加的字段也统一final表示常量 private final String key; private final String value; private ColorEnum(String key,String value){ this.key = key; this.value = value; } //根据key获取枚举 public static ColorEnum getEnumByKey(String key){ if(null == key){ return null; } for(ColorEnum temp:ColorEnum.values()){ if(temp.getKey().equals(key)){ return temp; } } return null; } public String getKey() { return key; } public String getValue() { return value; } }
3.枚举的好处以及与常量类的区别
1)枚举型可以直接与数据库打交道,我通常使用varchar类型存储,对应的是枚举的常量名。(数据库中好像也有枚举类型,不过也没用过)
2) switch语句支持枚举型,当switch使用int、String类型时,由于值的不稳定性往往会有越界的现象,对于这个的处理往往只能通过if条件筛选以及default模块来处理。而使用枚举型后,在编译期间限定类型,不允许发生越界的情况
3) 当你使用常量类时,往往得通过equals去判断两者是否相等,使用枚举的话由于常量值地址唯一,可以用==直接对比,性能会有提高
4) 常量类编译时,是直接把常量的值编译到类的二进制代码里,常量的值在升级中变化后,需要重新编译引用常量的类,因为里面存的是旧值。枚举类编译时,没有把常量值编译到代码里,即使常量的值发生变化,也不会影响引用常量的类。
5)枚举类编译后默认为final class,不允许继承可防止被子类修改。常量类可被继承修改、增加字段等,容易导致父类的不兼容。