132 文章 - 0 评论 - 73
</div><!--end: blogStats --> </div><!--end: navigator 博客导航栏 -->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">+加关注
< 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">我的随笔
我的评论
我的参与
最新评论
我的标签
随笔分类
</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>个人号可以吗
--醒时笑4. Re:Vue页面上实时显示当前时间,每秒更新@brealis 因为Date.now()不是响应式依赖,所以可能不会更新页面~,用其他方式吧...--靳哲5. Re:Vue页面上实时显示当前时间,每秒更新博主你好,我是新手,我试了一下computed,弄不出来,请问一下该怎么实现呢?
--brealisCopyright © 2020 靳哲 Powered by .NET Core on Kubernetes
</div><!--end: footer -->