Java中的枚举的治理
版权声明:本文为博主原创文章,转载请注明出处,欢迎使劲喷
一、为啥用枚举&为啥要对枚举进行治理
1.先来说说为啥用枚举
表中某个字段标识了这条记录的状态,我们往往使用一些code值来标识,例如01成功,00失败。
多状态共性的东西可以常量保存,例如
class Constants{
public static final String success = "01";
public static final String failure= "00";
}
然而,在一些大型项目中,表的数量极多,一些表中需要维护的状态也极多,如果都在如上的Constants中维护,试想如果添加一个状态值,那么需要在整个篇幅中找到对应的块,然后去新增值;修改呢?同样麻烦!!!
所以我们使用枚举,每个枚举类就只负责对一个状态做维护,这样我们方便增删改。例如:
/**
* Created by Bright on 2017/3/13.
*
* @author :
*/
public enum Payment {
Payment_WX("010000","微信支付"),
Payment_ZFB("010001","支付宝支付"),
Payment_YL("010002","银联支付"); public static Map<String,String> map = new HashMap<String, String>(); static{
Payment[] values = Payment.values();
if(values.length > 0){
for(Payment product : values){
map.put(product.getCode(),product.getName());
}
}
} Payment(String code, String name){
this.code = code;
this.name = name;
} private String code; private String name; public String getCode() {
return code;
} public void setCode(String code) {
this.code = code;
} public String getName() {
return name;
} public void setName(String name) {
this.name = name;
}
}
2.为啥要用java反射处理枚举呢?
我们之前看到了,使用Constants很方便,可以直接通过这个类的静态字段拿到值。当我们使用枚举时,当枚举类逐渐增多时,我们会发现,不同的地方我们需要获取不同的类,然后再通过不同的枚举获取到不同的值。这又势必是个头痛的事情。
那么我们想到了改进的方法:
改进一:把每个枚举类中放个map,把其code和name值映射进去,然后调用时通过静态map对象,把code值作为key传入,势必能获取到对应的描述。(如上段代码的map值)
然而,这个改进后,我们依旧需要找到这个类,然后去使用它的静态map,能不能只通过一个类进行统一治理呢?
改进二:通过一个类,把所有枚举在该类中注册,然后通过该类直接获取到相应的枚举值及name描述。
二、枚举治理的实现
1.先弄清我们使用枚举的场景
1.1通过枚举类中枚举名获取到枚举的code值(使用上面的枚举值定义)
例如:{"Payment_WX":"010000","Payment_YL":"010002","Payment_ZFB":"010001"}
if(param.equals(Payment.Payment_WX.getCode()){}
1.2通过枚举类中枚举的code值获取到对应的name描述(使用上面的枚举值定义)
例如:{"010002":"银联支付","010001":"支付宝支付","010000":"微信支付"}
Payment.map.get(Payment.Payment_WX.getCode());
2.枚举治理工具类的实现
/**
* Created by Bright on 2017/3/13.
*
* @author :
*/
public class VelocityEnumTools { public static final Logger logger = LoggerFactory.getLogger(VelocityEnumTools.class); //通过枚举获取枚举code值,例如:{"Payment_WX":"010000","Payment_YL":"010002","Payment_ZFB":"010001"}
public static Map<String,Map<String,String>> mapKeyCode = new HashMap<String, Map<String, String>>(); //通过code值获取枚举name,例如:{"010002":"银联支付","010001":"支付宝支付","010000":"微信支付"}
public static Map<String, Map<String, String>> mapCodeName = new HashMap<String, Map<String, String>>(); /**
* 需要在页面控制的enum,如Payment类似添加即可
*/
static {
//通过枚举获取code值
mapKeyCode.put(Payment.class.getSimpleName(), getEnumMap(Payment.class));
//通过code值获取枚举name
mapCodeName.put(Payment.class.getSimpleName(),getEnumCodeMap(Payment.class));
} /**
* 通过枚举获取code值
* @param enumKey
* @return
*/
public static Map<String, String> getKeyCodeMapperInstance(String enumKey) {
return mapKeyCode.get(enumKey);
} /**
* 通过code值获取枚举name
* @param enumKey
* @return
*/
public static Map<String, String> getCodeNameMapperInstance(String enumKey) {
return mapCodeName.get(enumKey);
} public static <T> Map<String, String> getEnumMap(Class<T> clazz) {
Map<String, String> map = new HashMap<String, String>();
try {
if (clazz.isEnum()) {
Object[] enumConstants = clazz.getEnumConstants();
for (int i = 0; i < enumConstants.length; i++) {
T t = (T) enumConstants[i];
Field code = t.getClass().getDeclaredField("code");
code.setAccessible(true);
map.put(t.getClass().getDeclaredFields()[i].getName(), (String) code.get(t));
}
}
} catch (NoSuchFieldException e) {
logger.error("枚举工具启动报错:{}", e);
} catch (IllegalAccessException e) {
logger.error("枚举工具启动报错:{}", e);
}
return map;
} private static <T> Map<String,String> getEnumCodeMap(Class<T> clazz) {
Map<String, String> map = new HashMap<String, String>();
try {
if (clazz.isEnum()) {
Object[] enumConstants = clazz.getEnumConstants();
for (int i = 0; i < enumConstants.length; i++) {
T t = (T) enumConstants[i];
Field code = t.getClass().getDeclaredField("code");
Field name = t.getClass().getDeclaredField("name");
code.setAccessible(true);
name.setAccessible(true);
map.put((String) code.get(t),(String) name.get(t));
}
}
} catch (NoSuchFieldException e) {
logger.error("枚举工具启动报错:{}", e);
} catch (IllegalAccessException e) {
logger.error("枚举工具启动报错:{}", e);
}
return map;
} public static void main(String[] args) throws NoSuchFieldException, IllegalAccessException {
Map<String, String> enumMap = getEnumMap(Payment.class);
System.out.println(JSON.toJSONString(enumMap));//{"Payment_WX":"010000","Payment_YL":"010002","Payment_ZFB":"010001"}
Map<String, String> enumCodeMap = getEnumCodeMap(Payment.class);
System.out.println(JSON.toJSONString(enumCodeMap));//{"010002":"银联支付","010001":"支付宝支付","010000":"微信支付"}
}
}
三、枚举治理的扩展-velocity中使用枚举
1.为什么会在velocity中使用枚举
当涉及与前端的交互时,我们可能需要从前端把三种支付方式对应的code值传到后台。
此时,如果在页面上直接写010000这样的值,那么页面的逻辑就很不直观了,今天写的时候你还能认知,为了防止自己忘了,除了加注释别无办法。
故,为了解决后台可用,且前端页面直观,所以我们希望尝试在页面上直接用枚举来解决问题。
2.看看页面如何处理(velocity页面中)
#set($payment=$enumTool.getCodeNameMapperInstance("Payment"))//直接写明要获取的枚举类型名称
#if($payment.get("Payment_WX") == $param.code)//通过枚举值获取其code值
//做微信支付页面逻辑
#end
2.velocity中配置velocity-tools
<?xml version="1.0" encoding="UTF-8"?>
<toolbox>
<tool>
<key>enumTool</key>
<class>com.bright.core.enumconstant.VelocityEnumTools</class>
</tool>
<tool>
<key>stringTool</key>
<class>org.apache.commons.lang.StringUtils</class>
</tool>
<tool>
<key>dateTool</key>
<class>org.apache.velocity.tools.generic.DateTool</class>
</tool>
</toolbox>
这样就可以简单的在页面中应用我们枚举治理工具了。
例如:通过code值获取到相应描述
$enumTool.getCodeNameMapperInstance("Payment").get($item.orderLoanStatus)//显示“微信支付”
通过枚举获取到对应的code值
#set($payment=$enumTool.getCodeNameMapperInstance("Payment"))//拿到了Payment的map
$payment.get("Payment_WX")
就此,我们可以实现系统的中的枚举治理,并且可在前端页面灵活应用。
Java中的枚举的治理的更多相关文章
- 【译】Java中的枚举
前言 译文链接:http://www.programcreek.com/2014/01/java-enum-examples/ Java中的枚举跟其它普通类很像,在其内部包含了一堆预先定义好的对象集合 ...
- Java中的枚举类型详解
枚举类型介绍 枚举类型(Enumerated Type) 很早就出现在编程语言中,它被用来将一组类似的值包含到一种类型当中.而这种枚举类型的名称则会被定义成独一无二的类型描述符,在这一点上和常量的定义 ...
- 扒一扒: Java 中的枚举
目录 1. 枚举的定义 1.1 传统的非枚举方法 1.2 枚举方法 1.3 定义总结 2 枚举的本质 2.1 继承 java.lang.Enum 2.2 final 类型 2.3 枚举常量本身就是该类 ...
- 全面解读Java中的枚举类型enum的使用
这篇文章主要介绍了Java中的枚举类型enum的使用,开始之前先讲解了枚举的用处,然后还举了枚举在操作数据库时的实例,需要的朋友可以参考下 关于枚举 大多数地方写的枚举都是给一个枚举然后例子就开始sw ...
- 用好Java中的枚举真的没有那么简单
1.概览 在本文中,我们将看到什么是 Java 枚举,它们解决了哪些问题以及如何在实践中使用 Java 枚举实现一些设计模式. enum关键字在 java5 中引入,表示一种特殊类型的类,其总是继承j ...
- JAVA中的枚举小结
枚举 将一组有限集合创建为一种新的类型,集合里面的值可以作为程序组件使用: 枚举基本特性 以下代码是枚举的简单使用: 使用values方法返回enum实例的数组 使用ordinal方法返回每个enum ...
- 说说Java中的枚举(一)
在实际编程中,往往存在着这样的“数据集”,它们的数值在程序中是稳定的,而且“数据集”中的元素是有限的.例如星期一到星期日七个数据元素组成了一周的“数据集”,春夏秋冬四个数据元素组成了四季的“数据集”. ...
- Android笔记:java 中的枚举
部分数据使用枚举比较方便,java中的enmu不如c#中使用方便 记录备忘 以c#中的代码为例 public enum PlayState { /// <summary> /// 关闭 / ...
- Java中Enum枚举的使用
三种不同的用法 注意项: 1.在switch中使用枚举能使代码的可读性更强. 2.如果要自定义方法,那么必须在enum实例序列的最后添加分号.而且Java要求必须先定义enum实例. 3.所有 ...
随机推荐
- JS-鼠标滚轮事件 和 阻止默认行为
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title> ...
- 数组的map方法
map方法 不支持IE6.7 .8 array1.map(fn) array1.map(fn[,thisArg]) 注意: fn 必须是函数,如果不是函数则会报错 TypeError: undefi ...
- java cooki的使用
session: 当新客户端发现一个HTTP请求时服务端会创建一个session.并分配一个sessionID作为服务端来客户端的识别,session对象会 保存在服务端.此时session对象处天N ...
- 华为oj---合并数组
题目标题: 将两个整型数组按照升序合并,并且过滤掉重复数组元素 详细描述: 接口说明 原型: voidCombineBySort(int* pArray1,intiArray1Num,int* pAr ...
- oracle_角色
一. 每个Oracle用户都有一个名字和口令,并拥有一些由其创建的表.视图和其他资源. Oracle角色(role)就是一组权限(privilege) (或者是每个用户根据其状态和条件所需的访问类型) ...
- java中的final与static
许多程序设计语言都有自己的办法告诉编译器某个数据是"常数".常数主要应用于下述两个方面: (1) 编译期常数,它永远不会改变 (2) 在运行期初始化的一个值,我们不希望它发生变化 ...
- uml系列(六)——行为图:活动&状态
说完uml的静态图了,说一下uml的动态的表示吧. uml的行为图,uml的行为图主要用来设计程序的行为.还是老规矩,先来张图: 行为图包含活动图和状态图两种. 先来说下活动图:活动图是由活动的节点和 ...
- mybatis随笔四之MapperProxy
在上一篇文章我们已经得到了mapper的代理对象,接下来我们对demoMapper.getDemo(1)这种语句进行分析.由于返回的mapper是个代理对象,因此会进入invoke方法,接下来我们来看 ...
- PrintWriter用法简析
public class PrintWriterextends Writer 向文本输出流打印对象的格式化表示形式.此类实现在 PrintStream 中的所有 print 方法.它不包含用于写入原始 ...
- 《Java从0开始的成长之路》
大纲 这篇博文是我整理寒假一个月来的总结 作用一:主要是方便我以后复习,并尝试对Java虚拟机深度挖掘,希望各位前辈给予指点,我会潜心钻研,只希望水平更进一步. 作用二:闭关锁国终将遭遗弃,希望汇聚网 ...