原代码:
可以看到逻辑上它是根据line字符串是否包含了某关键词,来做不同的处理,处理可能复杂或者简单,并且是有优先顺序关系的。 因此他使用了n个else-if来处理,每加1个关键词,圈复杂度就加1。
此问题处理的关键在于,如何根据不同关键词,去执行不同的操作,而且这个操作一般都很短。 那么根据以下思路:
- 不同关键字 -> 枚举类
- 执行不同操作 -> 枚举对象各持有1各 操作接口实现
- 操作行一般都很短 -> labamda表达式
那么我先定义1个set操作接口如下,提供给枚举类中各对象作为私有成员:
接着再定义枚举类:
然后枚举类中的枚举用lambda实现:
原方法中的if-else则就可以改为非常简单的:
来源:oschina
链接:https://my.oschina.net/edisonOnCall/blog/4352610