【转】java枚举使用详解

简介:

在实际编程中,往往存在着这样的“数据集”,它们的数值在程序中是稳定的,而且“数据集”中的元素是有限的。

例如星期一到星期日七个数据元素组成了一周的“数据集”,春夏秋冬四个数据元素组成了四季的“数据集”。

Java中如何更好的使用这些“数据集”呢?因此枚举便派上了用场,以下代码详细介绍了枚举的用法。

Java代码   收藏代码
  1. package com.ljq.test;  
  2.   
  3. /** 
  4.  * 枚举用法详解 
  5.  *  
  6.  * @author jiqinlin 
  7.  *  
  8.  */  
  9. public class TestEnum {  
  10.     /** 
  11.      * 普通枚举 
  12.      *  
  13.      * @author jiqinlin 
  14.      * 
  15.      */  
  16.     public enum ColorEnum {  
  17.         red, green, yellow, blue;  
  18.     }  
  19.       
  20.     /** 
  21.      * 枚举像普通的类一样可以添加属性和方法,可以为它添加静态和非静态的属性或方法 
  22.      *  
  23.      * @author jiqinlin 
  24.      * 
  25.      */  
  26.     public enum SeasonEnum {  
  27.         //注:枚举写在最前面,否则编译出错  
  28.         spring, summer, autumn, winter;  
  29.   
  30.         private final static String position = "test";  
  31.   
  32.         public static SeasonEnum getSeason() {  
  33.             if ("test".equals(position))  
  34.                 return spring;  
  35.             else  
  36.                 return winter;  
  37.         }  
  38.     }  
  39.       
  40.     /** 
  41.      * 性别 
  42.      *  
  43.      * 实现带有构造器的枚举 
  44.      *  
  45.      * @author jiqinlin 
  46.      * 
  47.      */  
  48.     public enum Gender{  
  49.         //通过括号赋值,而且必须带有一个参构造器和一个属性跟方法,否则编译出错  
  50.         //赋值必须都赋值或都不赋值,不能一部分赋值一部分不赋值;如果不赋值则不能写构造器,赋值编译也出错  
  51.         MAN("MAN"), WOMEN("WOMEN");  
  52.           
  53.         private final String value;  
  54.   
  55.         //构造器默认也只能是private, 从而保证构造函数只能在内部使用  
  56.         Gender(String value) {  
  57.             this.value = value;  
  58.         }  
  59.           
  60.         public String getValue() {  
  61.             return value;  
  62.         }  
  63.     }  
  64.       
  65.    /** 
  66.     * 订单状态 
  67.     *  
  68.     * 实现带有抽象方法的枚举 
  69.     *  
  70.     * @author jiqinlin 
  71.     * 
  72.     */  
  73.     public enum OrderState {  
  74.         /** 已取消 */  
  75.         CANCEL {public String getName(){return "已取消";}},  
  76.         /** 待审核 */  
  77.         WAITCONFIRM {public String getName(){return "待审核";}},  
  78.         /** 等待付款 */  
  79.         WAITPAYMENT {public String getName(){return "等待付款";}},  
  80.         /** 正在配货 */  
  81.         ADMEASUREPRODUCT {public String getName(){return "正在配货";}},  
  82.         /** 等待发货 */  
  83.         WAITDELIVER {public String getName(){return "等待发货";}},  
  84.         /** 已发货 */  
  85.         DELIVERED {public String getName(){return "已发货";}},  
  86.         /** 已收货 */  
  87.         RECEIVED {public String getName(){return "已收货";}};  
  88.           
  89.         public abstract String getName();  
  90.     }  
  91.       
  92.     public static void main(String[] args) {  
  93.         //枚举是一种类型,用于定义变量,以限制变量的赋值;赋值时通过“枚举名.值”取得枚举中的值  
  94.         ColorEnum colorEnum = ColorEnum.blue;  
  95.         switch (colorEnum) {  
  96.         case red:  
  97.             System.out.println("color is red");  
  98.             break;  
  99.         case green:  
  100.             System.out.println("color is green");  
  101.             break;  
  102.         case yellow:  
  103.             System.out.println("color is yellow");  
  104.             break;  
  105.         case blue:  
  106.             System.out.println("color is blue");  
  107.             break;  
  108.         }  
  109.           
  110.         //遍历枚举  
  111.         System.out.println("遍历ColorEnum枚举中的值");  
  112.         for(ColorEnum color : ColorEnum.values()){  
  113.             System.out.println(color);  
  114.         }  
  115.           
  116.         //获取枚举的个数  
  117.         System.out.println("ColorEnum枚举中的值有"+ColorEnum.values().length+"个");  
  118.           
  119.         //获取枚举的索引位置,默认从0开始  
  120.         System.out.println(ColorEnum.red.ordinal());//0  
  121.         System.out.println(ColorEnum.green.ordinal());//1  
  122.         System.out.println(ColorEnum.yellow.ordinal());//2  
  123.         System.out.println(ColorEnum.blue.ordinal());//3  
  124.           
  125.         //枚举默认实现了java.lang.Comparable接口  
  126.         System.out.println(ColorEnum.red.compareTo(ColorEnum.green));//-1  
  127.           
  128.         //--------------------------  
  129.         System.out.println("===========");  
  130.         System.err.println("季节为" + SeasonEnum.getSeason());  
  131.           
  132.           
  133.         //--------------  
  134.         System.out.println("===========");  
  135.         for(Gender gender : Gender.values()){  
  136.             System.out.println(gender.value);  
  137.         }  
  138.          
  139.         //--------------  
  140.         System.out.println("===========");  
  141.         for(OrderState order : OrderState.values()){  
  142.             System.out.println(order.getName());  
  143.         }  
  144.     }  
  145.       
  146. }  

 以下是我创建的一个枚举,表示签名算法

Java代码   收藏代码
  1. package com.common.enu;  
  2. /*** 
  3.  * 签名算法. 
  4.  * @author huangwei 
  5.  * @since 2013-10-28 
  6.  */  
  7. public enum SignatureAlgorithm {  
  8.     SIGNATURE_ALGORITHM_MD5withRSA("MD5withRSA"),  
  9.     SIGNATURE_ALGORITHM_SHA1withRSA("SHA1withRSA"),  
  10.     SIGNATURE_ALGORITHM_SHA256withRSA("SHA256withRSA");  
  11.       
  12.     private final String value;  
  13.   
  14.     //构造器默认也只能是private, 从而保证构造函数只能在内部使用  
  15.     private SignatureAlgorithm(String value) {  
  16.         this.value = value;  
  17.     }  
  18.       
  19.     public String getValue() {  
  20.         return value;  
  21.     }  
  22. }  

 测试:

Java代码   收藏代码
  1. @Test  
  2.     public void test_sign() throws Exception {  
  3.         String message = "whuang3";  
  4.         SignatureAlgorithm algorithm = SignatureAlgorithm.SIGNATURE_ALGORITHM_SHA256withRSA;  
  5.         byte[] signResult = SystemUtil.sign(message, privateKey, algorithm);  
  6.         System.out.println("sign result:" + new String(signResult));  
  7.         boolean isSuccess=SystemUtil.verifySign(message.getBytes(SystemUtil.CHARSET_ISO88591),  
  8.                 signResult, publicKey, algorithm);  
  9.         System.out.println("sign1 :"+isSuccess);  
  10.         Assert.assertEquals(isSuccess, true);  
  11.     }  
相关文章
|
2月前
|
安全 Java 测试技术
🎉Java零基础:全面解析枚举的强大功能
【10月更文挑战第19天】本文收录于「滚雪球学Java」专栏,专业攻坚指数级提升,希望能够助你一臂之力,帮你早日登顶实现财富自由🚀;同时,欢迎大家关注&&收藏&&订阅!持续更新中,up!up!up!!
124 60
|
2月前
|
Java
java小工具util系列4:基础工具代码(Msg、PageResult、Response、常量、枚举)
java小工具util系列4:基础工具代码(Msg、PageResult、Response、常量、枚举)
58 24
|
4月前
|
安全 Java 索引
Java——反射&枚举
本文介绍了Java反射机制及其应用,包括获取Class对象、构造方法、成员变量和成员方法。反射允许在运行时动态操作类和对象,例如创建对象、调用方法和访问字段。文章详细解释了不同方法的使用方式及其注意事项,并展示了如何通过反射获取类的各种信息。此外,还介绍了枚举类型的特点和使用方法,包括枚举的构造方法及其在反射中的特殊处理。
85 9
Java——反射&枚举
|
4月前
|
Java
java小工具util系列4:基础工具代码(Msg、PageResult、Response、常量、枚举)
java小工具util系列4:基础工具代码(Msg、PageResult、Response、常量、枚举)
96 5
|
8月前
|
安全 Java 程序员
Java语言枚举(Enum)的深入探索
Java语言枚举(Enum)的深入探索
107 0
|
4月前
|
安全 Java 开发者
Java 枚举(enum)详解
Java 中的枚举(`enum`)是一种特殊的数据类型,用于定义一组固定的常量,提升代码的类型安全性和可读性。枚举使用 `enum` 关键字定义,支持方法和构造函数,具有类型安全、单例、自动序列化等特点,并且可以遍历和用于 `switch` 语句中。实际应用包括状态机、指令集、类型标识等场景。枚举使代码更加清晰易维护。
311 1
|
5月前
|
Java
Java枚举使用的基本案例
这篇文章是关于Java枚举的基本使用,通过一个指令下发的代码案例,展示了如何定义枚举、使用枚举以及如何通过枚举实现指令的匹配和处理。
|
5月前
|
Java 开发者
在Java编程中,if-else与switch作为核心的条件控制语句,各有千秋。if-else基于条件分支,适用于复杂逻辑;而switch则擅长处理枚举或固定选项列表,提供简洁高效的解决方案
在Java编程中,if-else与switch作为核心的条件控制语句,各有千秋。if-else基于条件分支,适用于复杂逻辑;而switch则擅长处理枚举或固定选项列表,提供简洁高效的解决方案。本文通过技术综述及示例代码,剖析两者在性能上的差异。if-else具有短路特性,但条件增多时JVM会优化提升性能;switch则利用跳转表机制,在处理大量固定选项时表现出色。通过实验对比可见,switch在重复case值处理上通常更快。尽管如此,选择时还需兼顾代码的可读性和维护性。理解这些细节有助于开发者编写出既高效又优雅的Java代码。
72 2
|
5月前
|
安全 Java 编译器
|
6月前
|
存储 缓存 Java
java枚举消除冗余代码问题之findByName和findByValue方法工作时的问题如何解决
java枚举消除冗余代码问题之findByName和findByValue方法工作时的问题如何解决