博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
6 个重构方法可帮你提升 80% 的代码质量
阅读量:6932 次
发布时间:2019-06-27

本文共 1265 字,大约阅读时间需要 4 分钟。

hot3.png

 

  在过去做了不少代码走读,发现了一些代码质量上比较普遍的问题,以下是其中的前五名

  1. 臃肿的类

    类之所以会臃肿,是因为开发者缺乏对最基本的编码原则,即“单一职责原则”(SRP)的理解。这些类往往会变得很臃肿,是由于不同的且在功能上缺少关联的方法都放在了相同的类里面。

  2. 长方法

    方法之所以会变得很长主要是有以下几个原因:

  • 许多没有关联性的、功能复杂的模块的代码都放在相同的方法内。这主要是开发者缺乏SRP的概念。

  • 多种条件都放在同一个方法内,这在长方法内经常会发生的。这是由于缺乏McCabe代码复杂度和SRP的概念的比较。

大量的传参

我经常遇到这几种情况,一些方法跟另一些方法进行交互,或者调用另一些方法的时候传入大量的参数。这就会出现如果更改了其中一个参数,就得在多个方法内进行更改。

常量值无处不在

经常会发现开发者(尤其是新手)会使用一些具有明确含义的常量值(主要是魔鬼数字),但没有给它们赋予合适的常量变量。这会降低代码的可读性和可理解性。

模糊的方法名

许多时候,以下取的方法名会影响代码的可读性和可理解性:

  • 模糊的不具有任何意义的方法名

  • 技术性的,却没有提及相关领域的名称

  6个处理上面代码异味的重构方法(手法)

  以下是6个可以用来帮助你解决80%(80-20原则)的代码质量问题的重构方法,并能帮助你成为一个更优秀的开发者。

  1. /:正如上面提到的,像“臃肿的类”(一个类提供了本该有几个类提供的功能)这种代码异味应该将原有类中的方法和属性移动到适当数目的新类中去。旧类中对应新类的方法和属性应该被移除。另外,有时候一些类过于臃肿是因为它包含了被其他类使用本应该是其他类的成员方法的成员方法。这些方法也应该被迁移到合适的类中。

  2. :像上面提到的“过长的方法”这种代码异味可以通过从旧方法中提取代码到一个或多个新方法中消除。

  3. :许多时候,一个方法很长是因为包含好几个分支语句(if-else)。这些分支条件可以被提取和移动到几个单独的方法中。这确实能大大改善代码可读性和可理解性。

  4. /:在我做代码审查时发现另外一个很常见的情况 - 好几个参数被传入方法。问题主要与需要从已有方法中增加或者移除一个方法参数有关。在这种场景,建议将相关方法参数组成一个对象(引入参数对象),让方法传递这些对象而不是每个单独的参数。

  5. :对于有意义的并且到处被使用的字面常量,应该为它们分配一个命名常量。这能大大增强代码可读性和可理解性。

  6. : 正如上面提到的,模糊不清的方法名会影响代码的可使用性。这些模糊不清的名称应该重命名为有意义的可能与业务术语有关的名称,来帮助开发者通过业务上下文 更好地理解代码。这很需要技巧并且要求开发者与业务专家一起协作来理清代码需要满足的业务需求。有趣的是,这种重构方法看起来似乎非常容易理解,但是常常 被许多开发者忽视,虽然在Eclipse这种IDE的refactor菜单项中经常出现这一项。

转载于:https://my.oschina.net/Android1989/blog/334951

你可能感兴趣的文章
警惕IPSec/L2TP ×××被GFW干扰后变明文
查看>>
参数和基类
查看>>
HDFS与其他并行文件系统的比较
查看>>
总结:Windows Server 2003/2008远程桌面无法连接的解决方法
查看>>
我的友情链接
查看>>
MariaDB 10 Slave Crash-Safe需转为GTID复制模式
查看>>
千万别手欠执行stop slave
查看>>
调研《构建之法》指导下的历届作品
查看>>
不懂接口、反射、委托、设计模式足足写了5年的代码 -- 写给初学者(谈美女生成器不谈代码生成器)...
查看>>
如何把程序钉到Windows7任务栏(修正版)
查看>>
MySQL使用分库分表
查看>>
漂亮的点击弹出的登陆框
查看>>
MongoDB误操作后的point in time recovery
查看>>
底区:大盘见底八大征兆
查看>>
mysql 5.6.41创建新用户碰到的问题
查看>>
CSS设计指南(读书笔记 - 背景)
查看>>
DM***
查看>>
修改目录还原模式密码
查看>>
为什么有些人用了一年就获得了你十年的能力
查看>>
【C#】MemoryStream类的应用
查看>>