重构速查表

重构的相关技能
帅旋
关注
充电
IT宅站长,技术博主,架构师,全网id:arthinking。

代码的坏味道:不可维护

发布于 2019-03-08 | 更新于 2024-05-16

1 发散式变化(Divergent Change)

指一个类受多种变化的影响。

如果某个类经常因为不同原因在不同的方向上发生变化,Divergent Change(发散式变化)就出现了。

针对某一外界变化的所有相应修改,都只应该发生在单一类,而这个类内的所有内容都应该反应次变化。为此,你应该找出某特定原因而造成的所有变化,然后运营Extract Class(提炼类)将他们提炼到一个类中。

2 霰弹式修改(Shotgun Surgery)

指一种变化引发多个类相应修改。

如果每遇到一种变化,你都必须在许多不同的类内做出许多小修改,你所面临的坏味道就是Shotgun Surgery(霰弹式修改)

可以使用Move Method(搬移函数)Move Field(搬移字段)把所有需要修改的代码放进同一个类,如果没有合适的类,则创建一个。可以使用Inline Class(将类内联化)把一系列相关行为放进同一个类里面。这可能会造成少量的Divergent Change(发散式变化),但很容易处理掉。

3 平行继承体系(Parallel Inheritance Hierarchies)

Parallel Inheritance Hierarchies(平行继承体系)Shotgun Surgery(霰弹式修改)的特殊情况:每当你为某个类增加一个子类的时候,必须也为另一个类增加相应的子类,如果你发现某一个继承提醒的类前缀和另一个继承体系的类名称前缀完全相同,便是闻到了这种坏味道。

消除策略:让一个继承体系的实例引用另一个继承体系的实例。进一步的,运用Move Method(搬移函数)Move Field(搬移字段)将引用端继承体系消弥于无形。

本文作者: 帅旋

本文链接: https://www.itzhai.com/columns/refactoring/code-small-hard-to-modify.html

版权声明: 版权归作者所有,未经许可不得转载,侵权必究!联系作者请加公众号。

×
IT宅

关注公众号及时获取网站内容更新。

请帅旋喝一杯咖啡

咖啡=电量,给帅旋充杯咖啡,他会满电写代码!

IT宅

关注公众号及时获取网站内容更新。