一、通常的定义常量的方法

  1. public class Sex{
  2. public final static int MALE = 1;
  3. public final static int FEMALE=2;
  4. }

使用的时候,你能够在程序中直接引用这些常量。可是。这样的方式还是存在着一些问题。

  1. 类型不安全

因为颜色常量的相应值是整数形。所以程序运行过程中非常有可能给颜色变量传入一个随意的整数值。导致出现错误。

  1. 没有命名空间

因为颜色常量仅仅是类的属性,当你使用的时候不得不通过类来訪问。

  1. 一致性差

由于整形枚举属于编译期常量,所以编译过程完毕后,全部client和server端引用的地方。会直接将整数值写入。这样,当你改动旧的枚举整数值后或者添加新的枚举值后,全部引用地方代码都须要又一次编译,否则执行时刻就会出现错误。

  1. 打印不方便

二.经常使用emum定义常量

  1. public enum Sex {
  2. MALE , FEMALE;
  3. }

可是为了打印方便,你也能够给enum对象添加一个描写叙述

注意构造器仅仅能私有private,绝对不同意有public构造器
  1. public enum Sex {
  2. MALE("男") , FEMALE("女");
  3.  
  4. // 枚举对象的属性
  5. private String sexDescribtion;
  6.  
  7. // 枚举对象构造函数
  8. private Sex(String sx){
  9. this.sexDescribtion = sx;
  10. }
  11.  
  12. //覆盖方法
  13. @Override
  14. public String toString() {
  15. return this.sexDescribtion;
  16. }
  17.  
  18. }

这样,运行system.out.prntln(Sex.MALE)时。就会打印出 “男”



假设希望执行过程中Sex这个enum还能够改变描写叙述,比方:将MALE的描写叙述改为“男性”。则能够这样子
  1. public enum Sex {
  2. MALE("男") , FEMALE("女");
  3.  
  4. // 枚举对象的属性
  5. private String sexDescribtion;
  6.  
  7. // 枚举对象构造函数
  8. private Sex(String sx){
  9. this.sexDescribtion = sx;
  10. }
  11.  
  12. // 获取枚举对象的属性
  13. public String getSexDescribtion(){
  14. return sexDescribtion;
  15. }
  16.  
  17. // 改动枚举对象的属性
  18. public void setSexDescribtion(String sx){
  19. this.sexDescribtion = sx;
  20. }
  21.  
  22. //覆盖方法
  23. @Override
  24. public String toString() {
  25. return this.sexDescribtion;
  26. }
  27.  
  28. }
这样。就能够用setSexDescribtion来动态改变描写叙述了


Demo:

  1. package com.yjq.reflect;
  2.  
  3. public class User {
  4.  
  5. public enum Sex {
  6. MALE("男") , FEMALE("女");
  7.  
  8. // 枚举对象的属性
  9. private String sexDescribtion;
  10.  
  11. // 枚举对象构造函数
  12. private Sex(String sx){
  13. this.sexDescribtion = sx;
  14. }
  15.  
  16. // 获取枚举对象的属性
  17. public String getSexDescribtion(){
  18. return sexDescribtion;
  19. }
  20.  
  21. // 改动枚举对象的属性
  22. public void setSexDescribtion(String sx){
  23. this.sexDescribtion = sx;
  24. }
  25.  
  26. //覆盖方法
  27. @Override
  28. public String toString() {
  29. return this.sexDescribtion;
  30. }
  31.  
  32. }
  33.  
  34. private int id;
  35.  
  36. private String name;
  37.  
  38. private Sex sex;
  39.  
  40. public int getId() {
  41. return id;
  42. }
  43.  
  44. public void setId(int id) {
  45. this.id = id;
  46. }
  47.  
  48. public String getName() {
  49. return name;
  50. }
  51.  
  52. public void setName(String name) {
  53. this.name = name;
  54. }
  55.  
  56. public Sex getSex() {
  57. return sex;
  58. }
  59.  
  60. public void setSex(Sex sex) {
  61. this.sex = sex;
  62. }
  63.  
  64. @Override
  65. public String toString() {
  66. return "User [id=" + id + ", name=" + name + ", sex=" + sex + "]";
  67. }
  68.  
  69. public static void main(String[] args){
  70. User user = new User();
  71. user.setId(1);
  72. user.setName("Jim");
  73. user.setSex(Sex.MALE);
  74. System.out.println( "user_info:"+user.toString());
  75. }
  76. }

打印结果

  user_info:User [id=1, name=Jim, sex=男]



三. java中的enum解析 

摘自:http://www.cnblogs.com/frankliiu-java/archive/2010/12/07/1898721.html

  1. 1.enum Color{
  2. 2. RED(255,0,0),BLUE(0,0,255),BLACK(0,0,0),YELLOW(255,255,0),GREEN(0,255,0);
  3. 3. //构造枚举值。比方RED(255,0,0)
  4. 4. private Color(int rv,int gv,int bv){
  5. 5. this.redValue=rv;
  6. 6. this.greenValue=gv;
  7. 7. this.blueValue=bv;
  8. 8. }
  9. 9.
  10. 10. public String toString(){ //覆盖了父类Enum的toString()
  11. 11. return super.toString()+"("+redValue+","+greenValue+","+blueValue+")";
  12. 12. }
  13. 13.
  14. 14. private int redValue; //自己定义数据域,private为了封装。
  15. 15. private int greenValue;
  16. 16. private int blueValue;
  17. 17. }

1.   enum非常像特殊的class,实际上enum声明定义的类型就是一个类。 而这些类都是类库中Enum类的子类(java.lang.Enum<E>)

Sex枚举类就是class,并且是一个不能够被继承的final类。

其枚举值(MALE,FEMALE)都是Color类型的类静态常量, 我们能够通过以下的方式来得到Color枚举类的一个实例:

                                                         Color c=Color.MALE; 

注意:这些枚举值都是public static final的,也就是我们常常所定义的常量方式,因此枚举类中的枚举值最好所有大写。

2.  即然枚举类是class。当然在枚举类型中有构造器,方法和数据域。可是。枚举类的构造器有非常大的不同: 

        (1) 构造器仅仅是在构造枚举值的时候被调用

(2) 构造器仅仅能私有private。绝对不同意有public构造器

3.全部枚举类都继承了Enum的方法,以下我们具体介绍这些方法。 

       (1)  ordinal()方法: 返回枚举值在枚举类种的顺序。

这个顺序依据枚举值声明的顺序而定。

                 Color.RED.ordinal();  //返回结果:0

                 Color.BLUE.ordinal();  //返回结果:1

       (2)  compareTo()方法: Enum实现了java.lang.Comparable接口,因此能够比較象与指定对象的顺序。

Enum中的compareTo返回的是两个枚举值的顺序之差。当然,前提是两个枚举值必须属于同一个枚举类,否则会抛出ClassCastException()异常。(详细可见源码)

                 Color.RED.compareTo(Color.BLUE);  //返回结果 -1

       (3)  values()方法: 静态方法,返回一个包括所有枚举值的数组。

                 Color[] colors=Color.values();

                 for(Color c:colors){

                        System.out.print(c+","); 

                 }//返回结果:RED,BLUE,BLACK YELLOW,GREEN,

       (4)  toString()方法: 返回枚举常量的名称。

                 Color c=Color.RED;

                 System.out.println(c);//返回结果: RED

       (5)  valueOf()方法: 这种方法和toString方法是相相应的,返回带指定名称的指定枚举类型的枚举常量。

Color.valueOf("BLUE");   //返回结果: Color.BLUE

       (6)  equals()方法: 比較两个枚举类对象的引用

4、枚举类能够在switch语句中使用。

  1. 1.Color color=Color.RED;
  2. 2.switch(color){
  3. 3. case RED: System.out.println("it's red");break;
  4. 4. case BLUE: System.out.println("it's blue");break;
  5. 5. case BLACK: System.out.println("it's blue");break;
  6. 6.}

5. 两个工具类 EnumSet 和 EnumMap

摘自:http://www.ibm.com/developerworks/cn/java/j-lo-enum/

JDK5.0 中在添加 Enum 类的同一时候,也添加了两个工具类 EnumSet 和 EnumMap,这两个类都放在 java.util 包中。EnumSet 是一个针对枚举类型的高性能的 Set 接口实现。EnumSet 中装入的全部枚举对象都必须是同一种类型。在其内部,是通过 bit-vector 来实现。也就是通过一个 long 型数。EnumSet 支持在枚举类型的全部值的某个范围中进行迭代。回到上面日期枚举的样例上:

  1. enum WeekDayEnum { Mon, Tue, Wed, Thu, Fri, Sat, Sun }

你可以在每周七天日期中进行迭代。EnumSet 类提供一个静态方法 range 让迭代非常easy完毕:

  1. for(WeekDayEnum day : EnumSet.range(WeekDayEnum.Mon, WeekDayEnum.Fri)) {
  2. System.out.println(day);
  3. }

打印结果例如以下:

  1. Mon
  2. Tue
  3. Wed
  4. Thu
  5. Fri

EnumSet 还提供了非常多个类型安全的获取子集的 of 方法,使你非常easy取得子集:

  1. EnumSet<WeekDayEnum> subset = EnumSet.of(WeekDayEnum.Mon, WeekDayEnum.Wed);
  2. for (WeekDayEnum day : subset) {
  3. System.out.println(day);
  4. }

打印结果例如以下:

  1. Mon
  2. Wed

与 EnumSet 类似。EnumMap 也是一个高性能的 Map 接口实现。用来管理使用枚举类型作为 keys 的映射表。内部是通过数组方式来实现。

EnumMap 将丰富的和安全的 Map 接口与数组高速訪问结合到一起。假设你希望要将一个枚举类型映射到一个值,你应该使用 EnumMap。看以下的样例:

清单 5. EnumMap 演示样例
  1. // 定义一个 EnumMap 对象,映射表主键是日期枚举类型,值是颜色枚举类型
  2. private static Map<WeekDayEnum, RainbowColor> schema =
  3. new EnumMap<WeekDayEnum, RainbowColor>(WeekDayEnum.class);
  4.  
  5. static{
  6. // 将一周的每一天与彩虹的某一种色彩映射起来
  7. for (int i = 0; i < WeekDayEnum.values().length; i++) {
  8. schema.put(WeekDayEnum.values()[i], RainbowColor.values()[i]);
  9. }
  10. }
  11. System.out.println("What is the lucky color today?");
  12. System.out.println("It's " + schema.get(WeekDayEnum.Sat));

当你询问周六的幸运色彩时候,会得到蓝色:

清单 6. 执行结果
  1. What is the lucky color today?
  2.  
  3. It's BLUE

四.enum的作用

Enum 类型提出给 JAVA 编程带了了极大的便利。让程序的控制更加的easy,也不easy出现错误











Java中enum的学习总结的更多相关文章

  1. JAVA中enum的常见用法

    JAVA中enum的常见用法包括:定义并添加方法.switch.遍历.EnumSet.EnumMap 1.定义enum并添加或覆盖方法 public Interface Behaviour{ void ...

  2. Java中Enum类型的序列化(转)

    在Java中,对Enum类型的序列化与其他对象类型的序列化有所不同,今天就来看看到底有什么不同.下面先来看下在Java中,我们定义的Enum在被编译之后是长成什么样子的. Java代码: Java代码 ...

  3. Java中Enum枚举的使用

    三种不同的用法 注意项: 1.在switch中使用枚举能使代码的可读性更强.   2.如果要自定义方法,那么必须在enum实例序列的最后添加分号.而且Java要求必须先定义enum实例.   3.所有 ...

  4. java中enum类型的使用

    java 枚举类型enum 的使用 最近跟同事讨论问题的时候,突然同事提到我们为什么java 中定义的常量值不采用enmu 枚举类型,而采用public final static 类型来定义呢?以前我 ...

  5. java中容器的学习与理解

    以前一直对于java中容器的概念不理解,虽然学习过,但始终没有认真理解过,这几天老师提出了这样一个问题,你怎么理解java中的容器.瞬间就蒙了.于是各种搜资料学习了一下,下面是我学习后整理出来的的一些 ...

  6. Java中的equals学习小结

    Java中的equals是十分重要的,和= =要区别开来,现在小结其主要内容,而且要将 = =和 equals列为重要的对比概念来学习 1.声明格式    public  boolean equals ...

  7. java中BigDecimal的学习

    干着java的活,但是看的都是一些偏底层的东西(或者我根本就没有看),有点荒废了java的学习. 最近一直在用到一个类是BigDecimal,但都是模棱两可地在那儿用,并没有深入研究这个类的细节,感觉 ...

  8. 关于高淇JAVA中SORM总结学习笔记详细个人解释

    代码来源于高淇JAVA教学视频 谢谢高淇老师的教学. 因为自己在学习的过程中发现了很多困难点,总结下希望对自己接下来学框架提升.给像我一样得初学者方便. SORM框架是一个简单的ORM,关系对象映射, ...

  9. java 中LinkedList的学习

    Java中,所有链表实际上都是双向链表的,即每个结点还存放在着指向前驱结点的引用. LinkedList中的contains方法检测某个元素是否出现在链表中. LinkedList类提供了一个用来访问 ...

随机推荐

  1. 微信小程序异步处理

    直接看问题: 然后看打印的结果: 根据上面两图可以看出,代码上先执行的网络请求,再执行打印的变量,但是从下面打印的结果来看,先出结果的是执行打印变量的函数(aafn函数),再打印出网络请求succes ...

  2. java_IO流读取本地文件

    package com.ht.util; import java.io.File; import java.io.FileInputStream; import java.io.FileNotFoun ...

  3. Java中Comparable和Comparator比较

    1.Comparable 介绍 Comparable 是一个排序接口,如果一个类实现了该接口,说明该类本身是可以进行排序的.注意,除了基本数据类型(八大基本数据类型) 的数组或是List,其余类型的对 ...

  4. [转载] OAuth2.0认证和授权原理

    转载自http://www.tuicool.com/articles/qqeuE3 什么是OAuth授权? 一.什么是OAuth协议 OAuth(开放授权)是一个开放标准,允许第三方网站在用户授权的前 ...

  5. Google Python编程规范

    http://pan.baidu.com/s/1dD1Ra7J 其他语言的编程风格: http://zh-google-styleguide.readthedocs.org/en/latest/

  6. jvm内存区域与内存溢出

    java内存 java动态运行时区域包括:方法区.虚拟机栈.本地方法栈.堆.程序计数器,如右图所示:   程序计数器 程序计数器用来标识要执行的代码的行号,为线程私有   虚拟机栈 为线程所私有 虚拟 ...

  7. 一步一步搞懂支持向量机——从牧场物语到SVM(上)

    之前在数据挖掘课程上写了篇关于SVM的"科普文",尽量通俗地介绍了SVM的原理和对各公式的理解.最近给正在初学机器学习的小白室友看了一遍,他觉得"很好,看得很舒服&quo ...

  8. SpringMVC RequestMapping 详解

    SpringMVC RequestMapping 详解 RequestMapping这个注解在SpringMVC扮演着非常重要的角色,可以说是随处可见.它的知识点很简单.今天我们就一起学习Spring ...

  9. RecyclerView 加点击事件

    在apapter里去实现. View.OnClickListener onClickListener = new View.OnClickListener() { @Override public v ...

  10. ConstraintLayout+radioGroup做一个tab.简单好用。

    主页tab是必须会有的,各种实现也很多.各有千秋.但目标都是简单.可控.今天用ConstraintLayout+radioGroup做一个tab.简单性可控性都还可以.本文目的把ConstraintL ...