代码的坏味道

来源:互联网 发布:.gov是什么域名 编辑:程序博客网 时间:2024/04/24 20:15
1、Duplicated Code (重复代码)
         如果在一个以上的地点看到相同的程序结构,就应当设法将它们合而为一。

2、Long Method (过长函数)
         过长的程序不利于理解。每当感觉需要以注释来说明时,便可将此处代码写入一个独立函数中,并以其用途命名。

3、Large Class (过大类)
         如果一个class中出现过多的instance变量,就应当将几个相关的变量提炼到某个组件内。

4、Long Parameter List (过长参数列)
         太长的参数列难以理解也容易造成前后不一致、不易使用。

5、Divergent Change (发散式变化)
         一个class受到多种变化的影响。针对某一外界变化的所有相应修改,都只应该发生在单一class中,而这个新class内的所有内容都应该反应该外界变化。

6、Shotgun Surgy (散弹式修改)
         一种变化引发多个classes相应修改。此时应把所有需要修改的代码放进同一个class中。

7、Feature Envy (依恋情结)
         对象技术的全部要点在于:将数据和加诸其上的操作行为包装在一起。将总是一起变化的东西放在一起。

8、Data Clumps (数据泥团)
         将总是一起出现的数据放进属于它们自己的对象中

9、Primitive Obsession (基本型别偏执)

10、Switch Statements (Switch 惊悚现身)
         面向对象程序的一个明显特征就是:少用switch(或case)语句。大多数时候,一看到switch语句就应当考虑以多态来代替它。

11、Parallel Inheritance Hierarchies (平行继承体系)

12、Lazy Class (冗赘类)
         如果函数或class的唯一用户是 test cases ,就应当将其连同test cases一起删掉。

13、Speculative Generality (夸夸其谈未来性)

14、Temporary Field (令人迷惑的暂时值域)

15、Message Chains (过度耦合的消息链)

16、Middle Man (中间人)

17、Inappropriate Intimacy (狎昵关系)

18、Alternative Classes with Different Interfaces (异曲同工的类)

19、Incomplete Library Class (不完整的程序类库)
         Library的形式(form)往往不够好,往往不能让我们修改其中的classes使它完成希望完成的工作。

20、Data Class (单纯的数据类)

21、Refused Bequest (被拒绝的遗赠)

22、Comments (过多的注释)
         在感觉需要写注释时,首先尝试重构,用函数名表达注释所要解释的意思
原创粉丝点击