Java枚举

    技术2025-04-23  14

    靳哲

    </div><!--end: blogTitle 博客的标题和副标题 --> <div id="navigator"> 博客园 首页 新随笔 联系 订阅 管理 <div class="blogStats"> <span id="stats_post_count">随笔 -

    132  文章 - 0  评论 - 73

    </div><!--end: blogStats --> </div><!--end: navigator 博客导航栏 -->

    java中枚举类型的使用 </h1> <div class="clear"></div> <div class="postBody"> <div id="cnblogs_post_description" style="display: none"> java中枚举类型的简单使用 </div>

      Java 枚举(enum) 详解7种常见的用法

      JDK1.5引入了新的类型——枚举。在 Java 中它虽然算个“小”功能,却给我的开发带来了“大”方便。

     

      web项目里实体类使用枚举类型:

      一般在该实体类的包下在新建一个enumeration包,把枚举类型的类写在enumeration包下,例如:

    1 public enum Color { 2 RED, //红色 3 BLUE, //蓝色 4 GREEN //绿色 5 }

      然后在实体类里引用这个枚举类。

    1 @Enumerated(value = EnumType.STRING) 2 @Column(name = "color") 3 @NotNull 4 private Color color;

      注意:

    (1)@Enumerated(value=EnumType.ORDINAL)采用枚举类型的序号值与数据库进行交互,   此时数据库的数据类型需要是数值类型,例如在实际操作中 

    CatTest ct = new CatTest(); ct.setColor(Color.BLUE);

      当我们将对象ct保存到数据库中的时候,数据库中存储的数值是BLUE在Color枚举   定义中的序号1(序号从零开始);

    (2)@Enumerated(value=EnumType.STRING)采用枚举类型与数据库进行交互,   此时数据库的数据类型需要是NVACHAR2等字符串类型,例如在实际操作中 

    CatTest ct = new CatTest(); ct.setColor(Color.BLUR);

      数据库中存储的数值是BLUE字符串。

     

      枚举类型对象之间的值比较,是可以使用==,直接来比较值,是否相等的,不是必须使用equals方法的哟。

    用法一:常量  在JDK1.5 之前,我们定义常量都是: public static fianl.... 。现在好了,有了枚举,可以把相关的常量分组到一个枚举类型里,而且枚举提供了比常量更多的方法。

    1 public enum Color { 2 RED, GREEN, BLANK, YELLOW 3 }

     

    用法二:switch

    1 enum Signal { 2 GREEN, YELLOW, RED 3 } 4 public class TrafficLight { 5 Signal color = Signal.RED; 6 public void change() { 7 switch (color) { 8 case RED: 9 color = Signal.GREEN; 10 break; 11 case YELLOW: 12 color = Signal.RED; 13 break; 14 case GREEN: 15 color = Signal.YELLOW; 16 break; 17 } 18 } 19 }

     

    用法三:向枚举中添加新方法

    1 public enum Color { 2 RED("红色", 1), GREEN("绿色", 2), BLANK("白色", 3), YELLO("黄色", 4); 3 // 成员变量 4 private String name; 5 private int index; 6 // 构造方法 7 private Color(String name, int index) { 8 this.name = name; 9 this.index = index; 10 } 11 // 普通方法 12 public static String getName(int index) { 13 for (Color c : Color.values()) { 14 if (c.getIndex() == index) { 15 return c.name; 16 } 17 } 18 return null; 19 } 20 // get set 方法 21 public String getName() { 22 return name; 23 } 24 public void setName(String name) { 25 this.name = name; 26 } 27 public int getIndex() { 28 return index; 29 } 30 public void setIndex(int index) { 31 this.index = index; 32 } 33 }

     

    用法四:覆盖枚举的方法

      下面给出一个toString()方法覆盖的例子。 

    1 public enum Color { 2 RED("红色", 1), GREEN("绿色", 2), BLANK("白色", 3), YELLO("黄色", 4); 3 // 成员变量 4 private String name; 5 private int index; 6 // 构造方法 7 private Color(String name, int index) { 8 this.name = name; 9 this.index = index; 10 } 11 //覆盖方法 12 @Override 13 public String toString() { 14 return this.index+"_"+this.name; 15 } 16 }

     

    用法五:实现接口

      所有的枚举都继承自java.lang.Enum类。由于Java 不支持多继承,所以枚举对象不能再继承其他类。

    1 public interface Behaviour { 2 void print(); 3 String getInfo(); 4 } 5 public enum Color implements Behaviour{ 6 RED("红色", 1), GREEN("绿色", 2), BLANK("白色", 3), YELLO("黄色", 4); 7 // 成员变量 8 private String name; 9 private int index; 10 // 构造方法 11 private Color(String name, int index) { 12 this.name = name; 13 this.index = index; 14 } 15 //接口方法 16 @Override 17 public String getInfo() { 18 return this.name; 19 } 20 //接口方法 21 @Override 22 public void print() { 23 System.out.println(this.index+":"+this.name); 24 } 25 }

     

    用法六:使用接口组织枚举

    1 public interface Food { 2 enum Coffee implements Food{ 3 BLACK_COFFEE,DECAF_COFFEE,LATTE,CAPPUCCINO 4 } 5 enum Dessert implements Food{ 6 FRUIT, CAKE, GELATO 7 } 8 }

     

    用法七:关于枚举集合的使用

      java.util.EnumSet和java.util.EnumMap是两个枚举集合。EnumSet保证集合中的元素不重复;EnumMap中的 key是enum类型,而value则可以是任意类型。关于这个两个集合的使用就不在这里赘述,可以参考JDK文档。  关于枚举的实现细节和原理请参考:  参考资料:《ThinkingInJava》第四版  http://softbeta.iteye.com/blog/1185573

     

     

      参考:http://blog.csdn.net/qq_27093465/article/details/52180865

    分类: Java 标签: Java, 枚举 <div id="blog_post_info"> 好文要顶 关注我 收藏该文 靳哲 关注 - 17 粉丝 - 73 +加关注 3 0 <div class="clear"></div> <div id="post_next_prev"> <a href="https://www.cnblogs.com/jin-zhe/p/8258788.html" class="p_n_p_prefix">« </a> 上一篇: <a href="https://www.cnblogs.com/jin-zhe/p/8258788.html" title="发布于 2018-01-10 15:22">thymeleaf基本应用</a> <br> <a href="https://www.cnblogs.com/jin-zhe/p/8259524.html" class="p_n_p_prefix">» </a> 下一篇: <a href="https://www.cnblogs.com/jin-zhe/p/8259524.html" title="发布于 2018-01-10 16:53">java.time.ZonedDateTime</a> posted @ 2018-01-10 16:43  靳哲  阅读( 46215)  评论( 1)  编辑  收藏 </div><!--end: topics 文章、评论容器--> 评论列表    </div>

    #1楼

    <span id="comment-maxId" style="display:none">4304725</span> <span id="comment-maxDate" style="display:none">2019/7/20 下午4:32:14</span>

    2019-07-20 16:32

    <a id="a_comment_author_4304725" href="https://www.cnblogs.com/ynylub/" target="_blank">五莲山下一只蛙</a> </div> <div class="feedbackCon"> nice! 支持(0) 反对(0) https://pic.cnblogs.com/face/1662536/20200419205558.png </div> </div> <div id="sideBar"> <div id="sideBarMain">

    公告

    <div id="profile_block"> 昵称: <a href="https://home.cnblogs.com/u/jin-zhe/"> 靳哲 </a> <br> 园龄: <a href="https://home.cnblogs.com/u/jin-zhe/" title="入园时间:2018-01-04"> 2年6个月 </a> <br> 粉丝: <a href="https://home.cnblogs.com/u/jin-zhe/followers/"> 73 </a> <br> 关注: <a href="https://home.cnblogs.com/u/jin-zhe/followees/"> 17 </a> <div id="p_b_follow">

    +加关注

    < 2020年7月 > 日一二三四五六282930 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 1 2 3 4 5 6 7 8 <div id="leftcontentcontainer"> <div id="blog-sidecolumn">

    搜索

       

    常用链接

    我的随笔

    我的评论

    我的参与

    最新评论

    我的标签

    我的标签

    <li> <a href="https://www.cnblogs.com/jin-zhe/tag/Vue.js/">Vue.js</a>(41) </li> <li> <a href="https://www.cnblogs.com/jin-zhe/tag/js/">js</a>(22) </li> <li> <a href="https://www.cnblogs.com/jin-zhe/tag/Nuxt/">Nuxt</a>(10) </li> <li> <a href="https://www.cnblogs.com/jin-zhe/tag/Springboot/">Springboot</a>(8) </li> <li> <a href="https://www.cnblogs.com/jin-zhe/tag/element-ui/">element-ui</a>(5) </li> <li> <a href="https://www.cnblogs.com/jin-zhe/tag/vue/">vue</a>(5) </li> <li> <a href="https://www.cnblogs.com/jin-zhe/tag/%E6%9D%82%E8%AE%B0/">杂记</a>(4) </li> <li> <a href="https://www.cnblogs.com/jin-zhe/tag/Thymeleaf/">Thymeleaf</a>(4) </li> <li> <a href="https://www.cnblogs.com/jin-zhe/tag/nginx/">nginx</a>(3) </li> <li> <a href="https://www.cnblogs.com/jin-zhe/tag/es6/">es6</a>(3) </li> <li> <a href="https://www.cnblogs.com/jin-zhe/tag/">更多</a> </li> <div id="sidebar_postcategory" class="catListPostCategory sidebar-block"> <h3 class="catListTitle">

    随笔分类

    </h3> <ul> <li> Element-ui(4) </li> <li> es6语法(4) </li> <li> Git(1) </li> <li> H2 Database(2) </li> <li> Highcharts(1) </li> <li> IDEA(3) </li> <li> Java(2) </li> <li> java8(2) </li> <li> JavaScript(26) </li> <li> Liquibase(1) </li> <li> nginx(2) </li> <li> node.js(1) </li> <li> Nuxt(13) </li> <li> react.js(1) </li> <li> Spring(3) </li> <li> Spring Boot(8) </li> <li> Thymeleaf(5) </li> <li> TypeScript(2) </li> <li> Vant(2) </li> <li> Vue.js(31) </li> <li> vue-cli(2) </li> <li> Vuex(1) </li> <li> Vue基础用法(4) </li> <li> Vue使用小技巧(5) </li> <li> 前端面试题(3) </li> <li> 随笔感想(1) </li> <li> 微信公众号(5) </li> <li> 项目部署(1) </li> <li> 杂记(7) </li> <li> 正则表达式(2) </li> </ul> </div> <div id="sidebar_postarchive" class="catListPostArchive sidebar-block"> <h3 class="catListTitle">

    随笔档案

    </h3> <ul> <li> 2020年6月(5) </li> <li> 2020年5月(1) </li> <li> 2020年4月(2) </li> <li> 2020年3月(2) </li> <li> 2019年12月(6) </li> <li> 2019年11月(2) </li> <li> 2019年10月(2) </li> <li> 2019年9月(5) </li> <li> 2019年8月(1) </li> <li> 2019年3月(12) </li> <li> 2019年2月(3) </li> <li> 2019年1月(13) </li> <li> 2018年12月(15) </li> <li> 2018年11月(10) </li> <li> 2018年10月(11) </li> <li> 2018年9月(8) </li> <li> 2018年8月(3) </li> <li> 2018年7月(10) </li> <li> 2018年1月(21) </li> </ul> </div>

    最新评论

    <div class="RecentCommentBlock"> <ul> <li class="recent_comment_title"><a href="https://www.cnblogs.com/jin-zhe/p/9267912.html">1. Re:IDEA试用期结束以后继续试用(全部失效就更新),IDEA 2018 LICENSE SERVER</a></li> <li class="recent_comment_body"><p>直接用激活码可以看这边: <a href="" target="blank"></a></p> --清风付三2. Re:微信公众号本地开发流程@醒时笑 可以的啊...--靳哲3. Re:微信公众号本地开发流程

    个人号可以吗

    --醒时笑4. Re:Vue页面上实时显示当前时间,每秒更新@brealis 因为Date.now()不是响应式依赖,所以可能不会更新页面~,用其他方式吧...--靳哲5. Re:Vue页面上实时显示当前时间,每秒更新

    博主你好,我是新手,我试了一下computed,弄不出来,请问一下该怎么实现呢?

    --brealis

    阅读排行榜

    1. Vue中watch的简单应用(312891) 2. Vue子组件调用父组件的方法(104258) 3. spring学习之@ModelAttribute运用详解(81794) 4. Vue中使用定时器setInterval和setTimeout(67906) 5. Vue.js中this.$nextTick()的使用(54358)

    评论排行榜

    1. Vue子组件调用父组件的方法(11) 2. IDEA试用期结束以后继续试用(全部失效就更新),IDEA 2018 LICENSE SERVER(10) 3. element-UI中el-select下拉框可搜索时候,filter-method自定义搜索方法(6) 4. Vue中watch的简单应用(5) 5. Nuxt使用Vuex(4)

    推荐排行榜

    1. Vue中watch的简单应用(15) 2. Vue子组件调用父组件的方法(9) 3. spring学习之@ModelAttribute运用详解(8) 4. Vue.js中this.$nextTick()的使用(4) 5. java中枚举类型的使用(3) </div><!--end: sideBarMain --> </div><!--end: sideBar 侧边栏容器 --> <div class="clear"></div> </div><!--end: main --> <div class="clear"></div> <div id="footer"> <!--done-->

    Copyright © 2020 靳哲 Powered by .NET Core on Kubernetes

    </div><!--end: footer -->
    Processed: 0.013, SQL: 9