转载自:http://www.ablanxue.com/prone_5481_1.html
说if-else过多的分支可以使用switch或者责任链模式等等方式来优化。确实,这是一个小问题,不过我们还是可以整理一下这个小问题的重构方式。
为什么要优化?
有许多人会说,叠起来一堆if-else分支,代码就不优雅了。可是,怎样去定义“优雅”的概念呢?再退一步说,即便不“优雅”,又有什么问题?
对于这样一段再普通不过的代码:
intcode;
if("Name".equals(str))
code =0;elseif("Age".equals(str))code =1;elseif("Address".equals(str))
code =2;
...
寻找代替分支判断的方式
接下去我们再来考虑怎么样去重构优化过多的if-else分支。
1. 用一个Map可以做到,if-else的变化点使用Map的get方法来代替: Map typeCodeMap =newHashMap();
typeCodeMap.put("Name",0);
typeCodeMap.put("Age",1);
typeCodeMap.put("Address",2);
...
intcode = typeCode.get(type);
2. 枚举:
publicenumCodes {
Name(0), Age(1), Address(2);
publicintcode;
Codes(intcode){
this.code = code;
}
}
//使用:
intcode = Codes.valueOf(str).code;3. 多态: