前言

开发零碎一些状态,比方订单状态:数据库存储是数字或字母,然而须要显示中文或英文,个别用到if-else代码判断,但这种判断可读性比拟差,也会影响前期保护,也比拟容易呈现bug。比方:
假如状态对应关系:1:agree 2:refuse 3:finish

int status;String statusStr = null;if (status == 1) {   status = "agree";} else if (status == 2) {   status = "refuse";}else if(status == 3) {    status = “finish”;}

计划一: 数组

这种仅限通过数字获取到字母或者中文。
首先设置数组

String[] statusArray = {"","agree","refuse","finish"};

通过数组的地位获取数组的值

int status;String statusStr =  statusArray[status];

长处: 占用内存少
毛病: 状态值只能是数字,而且还须要思考数组越界状况

计划二:HashMap

创立和增加map:

    private static final Map<Integer,String> map = new HashMap<>();    static {        map.put(1,"agree");        map.put(2,"refuse");        map.put(3,"finish");    }

这种有两种求解形式,通过 key 获取 value 以及通过 value 获取 key,

由 key 获取 value

间接应用 get 办法即可。这里的key绝对于数组解法,不限度 key 的类型。

int status;map.get(status);

由 value 获取 key

应用map遍历:

int status;for(Map.Entry<Integer, String> vo : map.entrySet()){     if (vo.getValue().equals(result)) {           status = vo.getKey();           break;      }}

长处:状态值不限度数字
毛病:占用空间大

解决方案三、枚举

先定义一个枚举类

public enum TestEum {    agree(1,"agree"),    refuse(2,"refuse");    private int code;    private String capation;    TestEum(int code,String capation){        this.code = code;        this.capation = capation;    }    public int getCode() {        return code;    }   public String getCapation() {        return capation;   }     String of(int code){        for (TestEum testEum : TestEum.values()) {            if (testEum.getCode() == code) {                return testEum.getCapation();            }        }        return null;    } }

有了枚举当前,if-else 代码块能够优化成一行代码

String statusStr = TestEum.of(status);

总结

  1. 如果通过数字获取形容,应用数组即可。
  2. 如果通过形容获取数字,应用枚举和HashMap都能够。