【送给新手】重复代码解决示例一
  TEZNKK3IfmPf 2024年03月22日 34 0

重复代码

第一个例子:

第一个方法:getCount

【送给新手】重复代码解决示例一

第二个方法:pageQueryKbdb

【送给新手】重复代码解决示例一

上面两个方法中,第一个是求总数,第二个方法是分页查询详细内容。

这两个方法的SQL中除了select count(ID)不一样,其他一模一样,这样的代码,如果将来SQL变了,你需要同时修改两个地方,如果没有注意,两个SQL不一致,结果会差很多。

上面的的SQL完全可以从from KBJCJL这里开始单独创建一个方法,方法返回一个String类型的SQL即可。

将上面的两个方法修改后如下:

增了一个方法getKbdsSql

【送给新手】重复代码解决示例一

【送给新手】重复代码解决示例一

原来的两个方法修改为:

【送给新手】重复代码解决示例一

上面这种修改方式很容易,主要是因为这两个SQL差异太小,但是如果JAVA处理SQL时,不同的地方很多,可能需要上面的方法再拆分成多个方法重新组合。

这个类中,还有多处类似的代码,看下面的GetClCount方法:

【送给新手】重复代码解决示例一

你觉得这个方法眼熟吗?

但是这个方法写的和前面的两个方法不一样,但是逻辑呢?

其实逻辑一模一样,而且结果也一样,并且这里写的switch-case比上面的要规范,为什么?

因为这里的case是从1到18排列的,并且其中的13、14是用default处理的。

只有13对应的值不一样

所以这看着不一样的代码却做着几乎相同的事,非常的不合理。

完全可以在提取的方法中,单独写出case 13进行处理。

然后GetClCount方法完全可以调用修改后的方法。

记住:

a.      如果有一段代码出现了两次,如果代码很短(4,5行),而且结构不是很好,可以直接复制。如果代码很长,将代码独立出来。

b.      如果方法出现了两次以上,将代码独立出来。

c.      不同类如果调用相同的方法,可以独立到一个公共类中,所有的类都调用这一个类的方法,而不是把该方法分别复制到每个类中。

不知道你们觉得上面的方法修改之后感觉怎么样??????

如果你觉得这样就可以了,那你就错了。

你有没有注意到这样的代码:

【送给新手】重复代码解决示例一

像这种代码,如果维护起来,极其的不方便。

你应该注意到这里的代码有一个特点,就是case对应的值,并且这些值只是在SQL中使用的,那么为什么不将这种对应关系存入到数据库中呢?

如果将上面的关系存入到表中,那么完全不需要switch处理,直接用SQL查询关联就可以处理。

【版权声明】本文内容来自摩杜云社区用户原创、第三方投稿、转载,内容版权归原作者所有。本网站的目的在于传递更多信息,不拥有版权,亦不承担相应法律责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@moduyun.com

  1. 分享:
最后一次编辑于 2024年03月22日 0

暂无评论

推荐阅读
  TEZNKK3IfmPf   17天前   40   0   0 java
TEZNKK3IfmPf