美文网首页
22种代码的坏味道(转载)

22种代码的坏味道(转载)

作者: Thread_921 | 来源:发表于2019-05-14 15:07 被阅读0次

    假设一段代码是不稳定或者有一些潜在问题的,那么代码往往会包括一些明显的痕迹。
    正如食物要腐坏之前,常常会发出一些异味一样。
    我们管这些痕迹叫做“代码异味”。

    參考资料:

    Bad Smell(代码的坏味道)

    解决方法:提取公共函数。

    解决方法:拆分成若干函数。

    解决方法:拆分成若干类。

    解决方法:将參数封装成结构或者类。

    • Divergent Change -------(万能类)发散试改动,改好多需求,都会动他。

    解决方法:拆,将总是一起变化的东西放在一块儿。

    • Shotgun Surgery --------(天女散花的逻辑)散弹试改动,改某个需求的时候,要改非常多类。

    解决方法:将各个改动点,集中起来,抽象成一个新类。

    • Feature Envy -----------(红杏出墙的函数)使用了大量其它类的成员

    解决方法:将这个函数挪到那个类里面。

    • Data Clumps ------------(数据团)常一起出现的一坨数据。

    解决方法:他们那么有基情,就在一起吧,给他们一个新的类。

    • Primitive Obsession ----(偏爱基本类型)热衷于使用int,long,String等基本类型。

    解决方法:重复出现的一组參数,有关联的多个数组换成类吧。

    解决方法:state/strategy 或者仅仅是简单的多态。

    解决方法:应该有一个类是能够去掉继承关系的。

    • Lazy Class -------------------------------------(冗赘类)假设他不干活了,炒掉他吧。

    解决方法:把这些不再重要的类里面的逻辑,合并到相关类,删掉旧的。

    解决方法:删掉

    • Temporary Field --------------------------------(暂时字段)仅在特定环境下使用的变量

    解决方法:将这些暂时变量集中到一个新类中管理。

    • Message Chains ---------------------------------(消息链)过度耦合的才是坏的。

    解决方法:拆函数或者移动函数。

    • Middle Man -------------------------------------(中介)大部分都交给中介来处理了。

    解决方法:用继承替代托付。

    • Inappropriate Intimacy -------------------------(太亲热)两个类彼此使用对方的私有的东西。

    解决方法:划清界限拆散,或合并,或改成单项联系。

    解决方法:重命名,移动函数,或抽象子类。

    解决方法:包一层函数或包成新的类。

    • Data Class -------------(纯数据类)类非常easy,仅有公共成员变量,或简单操作函数。

    解决方法:将相关操作封装进去,降低public成员变量。

    • Refused Bequest --------(继承过多)父类里面方法非常多,子类仅仅用有限几个。

    解决方法:用代理替代继承关系。

    • Comments ---------------(太多凝视)这里指代码太难懂了,不得不用凝视解释。

    解决方法:避免用凝视解释代码,而是说明代码的目的,背景等。好代码会说话。

    相关文章

      网友评论

          本文标题:22种代码的坏味道(转载)

          本文链接:https://www.haomeiwen.com/subject/kyisaqtx.html