什么是代码异味
代码异味 就是代码写得差的征兆或表征。
假设一段代码是不稳定或者有一些潜在问题的,那么代码往往会包括一些明显的痕迹。
正如食物要腐坏之前,常常会发出一些异味一样。
我们管这些痕迹叫做“代码异味”。
代码异味的种类
(即代码写得不太好、有隐患的种类)
Code Smells
-
Code smells
-
Duplicated Code --------(反复代码)难维护。
[解决方法]:提取公共函数。
-
Long Method ------------(函数长)难理解。
[解决方法]:拆分成若干函数。
-
Large Class ------------(类大)难理解。
[解决方法]:拆分成若干类。
-
Long Parameter List ----(參数多)难用,难理解。
-
[解决方法]:将參数封装成结构或者类。
-
Divergent Change -------(万能类)发散试改动,改好多需求,都会动他。
[解决方法]:拆,将总是一起变化的东西放在一块儿。
-
Shotgun Surgery --------(天女散花的逻辑)散弹试改动,改某个需求的时候,要改非常多类。
[解决方法]:将各个改动点,集中起来,抽象成一个新类。
-
Feature Envy -----------(红杏出墙的函数)使用了大量其它类的成员
[解决方法]:将这个函数挪到那个类里面。
-
Data Clumps ------------(数据团)常一起出现的一坨数据。
[解决方法]:他们那么有基情,就在一起吧,给他们一个新的类。
-
Primitive Obsession ----(偏爱基本类型)热衷于使用int,long,String等基本类型。
[解决方法]:重复出现的一组參数,有关联的多个数组换成类吧。
-
Switch Statements ------(switch语句)
[解决方法]:state/strategy 或者仅仅是简单的多态。
-
Parallel Inheritance Hierarchies ---------------(平行继承)添加A类的子类ax,B类也须要对应的添加一个bx。
[解决方法]:应该有一个类是能够去掉继承关系的。
-
Lazy Class -------------------------------------(冗赘类)假设他不干活了,炒掉他吧。
[解决方法]:把这些不再重要的类里面的逻辑,合并到相关类,删掉旧的。
-
Speculative Generality -------------------------(夸夸其谈未来性)
[解决方法]:删掉
-
Temporary Field --------------------------------(暂时字段)仅在特定环境下使用的变量
[解决方法]:将这些暂时变量集中到一个新类中管理。
-
Message Chains ---------------------------------(消息链)过度耦合的才是坏的。
[解决方法]:拆函数或者移动函数。
-
Middle Man -------------------------------------(中介)大部分都交给中介来处理了。
[解决方法]:用继承替代托付。
-
Inappropriate Intimacy -------------------------(太亲热)两个类彼此使用对方的私有的东西。
[解决方法]:划清界限拆散,或合并,或改成单项联系。
-
Alternative Classes with Different Interfaces --(相似的类,有不同接口)
[解决方法]:重命名,移动函数,或抽象子类。
-
Incomplete Library Class -----------------------(不完好的类库)
[解决方法]:包一层函数或包成新的类。
-
Data Class -------------(纯数据类)类非常easy,仅有公共成员变量,或简单操作函数。
[解决方法]:将相关操作封装进去,降低public成员变量。
-
Refused Bequest --------(继承过多)父类里面方法非常多,子类仅仅用有限几个。
[解决方法]:用代理替代继承关系。
-
Comments ---------------(太多凝视)这里指代码太难懂了,不得不用凝视解释。
[解决方法]:避免用凝视解释代码,而是说明代码的目的,背景等。好代码会说话。
代码异味检测工具
(既检测代码写的有哪些问题、哪些隐患的工具)
下面的介绍都比较老了,仅做参考:
表2对这七个工具所能够探测到的代码味道进行了统计,作为商业工具的inFusion所能够识别到的代码味道最多(12种),其次是iPlasma(11种)。