同步操作将从 turnon/blog 强制同步,此操作会覆盖自 Fork 仓库以来所做的任何修改,且无法恢复!!!
确定后同步将在后台操作,完成时将刷新页面,请耐心等待。
title: 代码坏味道之变革的障碍
date: 2018-10-13 22:48:00
categories:
- 设计
- 重构
tags:
- 设计
- 重构
- 代码的坏味道
permalink: /pages/56ca63/
翻译自:https://sourcemaking.com/refactoring/smells/change-preventers
变革的障碍(Change Preventers)这组坏味道意味着:当你需要改变一处代码时,却发现不得不改变其他的地方。这使得程序开发变得复杂、代价高昂。
发散式变化(Divergent Change)
类似于霰弹式修改(Shotgun Surgery)
,但实际上完全不同。发散式变化(Divergent Change)
是指一个类受多种变化的影响。霰弹式修改(Shotgun Surgery)
是指多种变化引发多个类相应的修改。
你发现你想要修改一个函数,却必须要同时修改许多不相关的函数。例如,当你想要添加一个新的产品类型时,你需要同步修改对产品进行查找、显示、排序的函数。
通常,这种发散式修改是由于编程结构不合理或者“复制-粘贴式编程”。
提炼类(Extract Class)
拆分类的行为。问题
某个类做了不止一件事。
解决
建立一个新类,将相关的字段和函数从旧类搬移到新类。
平行继承体系(Parallel Inheritance Hierarchies)
其实是霰弹式修改(Shotgun Surgery)
的特殊情况。
每当你为某个类添加一个子类,必须同时为另一个类相应添加一个子类。这种情况的典型特征是:某个继承体系的类名前缀或类名后缀完全相同。
起初的继承体系很小,随着不断添加新类,继承体系越来越大,也越来越难修改。
搬移函数(Move Method)
和 搬移字段(Move Field)
,就可以消除引用端的继承体系。问题
你的程序中,有个函数与其所驻类之外的另一个类进行更多交流:调用后者,或被后者调用。
解决
在该函数最常引用的类中建立一个有着类似行为的新函数。将旧函数变成一个单纯的委托函数,或是旧函数完全移除。
问题
在你的程序中,某个字段被其所驻类之外的另一个类更多地用到。
解决
在目标类新建一个字段,修改源字段的所有用户,令他们改用新字段。
霰弹式修改(Shotgun Surgery)
类似于发散式变化(Divergent Change)
,但实际上完全不同。发散式变化(Divergent Change)
是指一个类受多种变化的影响。霰弹式修改(Shotgun Surgery)
是指多种变化引发多个类相应的修改。
任何修改都需要在许多不同类上做小幅度修改。
一个单一的职责被拆分成大量的类。
搬移函数(Move Method)
和 搬移字段(Move Field)
来搬移不同类中相同的行为到一个独立类中。如果没有适合存放搬移函数或字段的类,就创建一个新类。将类内联化(Inline Class)
将一些列相关行为放进同一个类。问题
你的程序中,有个函数与其所驻类之外的另一个类进行更多交流:调用后者,或被后者调用。
解决
在该函数最常引用的类中建立一个有着类似行为的新函数。将旧函数变成一个单纯的委托函数,或是旧函数完全移除。
问题
在你的程序中,某个字段被其所驻类之外的另一个类更多地用到。
解决
在目标类新建一个字段,修改源字段的所有用户,令他们改用新字段。
问题
某个类没有做太多事情。
解决
将这个类的所有特性搬移到另一个类中,然后移除原类。
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。