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