优化代码中大量的if/else,你有什么方案?

一个快速迭代的项目,时间久了以后,代码中可能会充斥着大量的if/else,嵌套六、7层,一个函数几百行,简!直!看!死!人!
其实这种还算好的,更严重的嵌套我也见过,接手到这种项目的人,心里应该是绝望的。
出现这种状况的缘由不少
  • 设计不够完善
  • 需求考虑不彻底
  • 开发人员变更
但最为致命的是“懒”,没有梦想是件很可怕的事情!
前期迭代懒得优化,来一个需求,加一个if,长此以往,就串成了一座金字塔。
当代码已经复杂到难以维护的程度以后,只能狠下心重构优化。那,有什么方案能够优雅的优化掉这些多余的if/else?

01 提早return

这是判断条件取反的作法,代码在逻辑表达上会更清晰,看下面代码:
其实,每次看到上面这种代码,我都内心抓痒,彻底能够先判断!condition,干掉else。

02 策略模式

有这么一种场景,根据不一样的参数走不一样的逻辑,其实这种场景很常见。 最通常的实现:
看上面代码,有4种策略,有两种优化方案。

2.1 多态

具体策略对象存放在一个Map中,优化后的实现
上面这种优化方案有一个弊端,为了可以快速拿到对应的策略实现,须要map对象来保存策略,当添加一个新策略的时候,还须要手动添加到map中,容易被忽略。

2.2 枚举

发现不少同窗不知道在枚举中能够定义方法,这里定义一个表示状态的枚举,另外能够实现一个run方法。
从新定义策略枚举
经过枚举优化以后的代码以下

03 学会使用 Optional

Optional主要用于非空判断,因为是jdk8新特性,因此使用的不是特别多,可是用起来真的爽。 使用以前:
若是登陆用户为空,执行action1,不然执行action 2,使用Optional优化以后,让非空校验更加优雅,间接的减小if操做

04 数组小技巧

来自google解释,这是一种编程模式,叫作表驱动法,本质是从表里查询信息来代替逻辑语句,好比有这么一个场景,经过月份来获取当月的天数,仅做为案例演示,数据并不严谨。 通常的实现:
优化后的代码

05 结语

if else做为每种编程语言都不可或缺的条件语句,在编程时会大量的用到。通常建议嵌套不要超过三层,若是一段代码存在过多的if else嵌套,代码的可读性就会急速降低,后期维护难度也大大提升。 若是你还有其它小技巧,欢迎留言!!!
相关文章
相关标签/搜索