java中过多if-else分支语句的优化方案

转载自:http://www.ablanxue.com/prone_5481_1.html

说if-else过多的分支可以使用switch或者责任链模式等等方式来优化。确实,这是一个小问题,不过我们还是可以整理一下这个小问题的重构方式。



为什么要优化?

有许多人会说,叠起来一堆if-else分支,代码就不优雅了。可是,怎样去定义“优雅”的概念呢?再退一步说,即便不“优雅”,又有什么问题?

对于这样一段再普通不过的代码:

 
  1. int code;   
  2. if("Name".equals(str))   
  3.  code = 0;   
  4. else if("Age".equals(str))   
  5.  code = 1;   
  6. else if("Address".equals(str))   
  7.  code = 2;   
  8. ... 
  9. 寻找代替分支判断的方式

    接下去我们再来考虑怎么样去重构优化过多的if-else分支。

    1. 用一个Map可以做到,if-else的变化点使用Map的get方法来代替:

        
    1. Map typeCodeMap = new HashMap();   
    2. typeCodeMap.put("Name"0);   
    3. typeCodeMap.put("Age"1);   
    4. typeCodeMap.put("Address"2);   
    5. ...   
    6. int code = typeCode.get(type); 

      2. 枚举:

             
      1. public enum Codes {   
      2.     Name(0), Age(1), Address(2);   
      3.     public int code;   
      4.     Codes(int code){   
      5.         this.code = code;   
      6.     }   
      7. }   
      8. //使用:   
      9. int code = Codes.valueOf(str).code; 
    3. 多态:

已标记关键词 清除标记
相关推荐
©️2020 CSDN 皮肤主题: 技术工厂 设计师:CSDN官方博客 返回首页
实付 49.90元
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、C币套餐、付费专栏及课程。

余额充值