代码设计篇—别再用if else了!

笔者一看到一大串的if else就会头皮发麻,尤其是if里套一大段代码,else里再给你来个一大段代码,看到这样的代码笔者真的有种想摔键盘砸电脑的冲动,为了不损坏公司电脑,笔者只能放弃阅读。这种代码不易扩展,更不易后续接手的人维护。写代码讲究“开扩展闭修改”,一段代码只要被打开就存在被修改的风险。下面介绍三种替代的方案。

1 注入Map

逻辑复杂,需要根据条件分别处理的,可以采用注入Map的方式解决。以学生和老师为例,学生和老师属于用户。代码结构如下图:
在这里插入图片描述
StudentServiceImpl和TeacherServiceImpl实现UserService,service的id与枚举UserType保持一致,UserBizService调用UserService的add方法来新增学生或老师。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
Map注入时,spring会将service的id作为Map的key
在这里插入图片描述

2 注入List

逻辑复杂,需要根据条件分别处理的,可以采用注入List的方式解决。还是以上面的例子为例,这个时候需要引入@Order注解,也就是把service按照指定的顺序注入到List里。
在这里插入图片描述
在这里插入图片描述
排序的好处就是能根据索引取到想要的service
在这里插入图片描述

3 枚举+switch

如果逻辑简单,两三行代码就能搞定的且条件较多,可以采用枚举+switch的方式解决。
在这里插入图片描述
以上只是简单的举例,可以变通出很多种玩法,读者可以自行尝试一下。

猜你喜欢

转载自blog.csdn.net/weixin_45497155/article/details/105633013