在对象之间搬移特性
1. Move Method(搬移函数)
Q:你的程序中,有个函数与其所驻类之外的另一个类进行更多交流:调用后者,或被后者调用
A:在该函数最常引用的类中建立一个有着类似行为的新函数,将旧函数变成一个单纯的委托函数,或是将旧函数完全移除。
2. Move Field(搬移字段)
Q:在你的程序中,某个字段被其所驻类之外的另一个类更多地用到。
A:在目标类新建一个字段,修改源字段的所有用户,令它们改用新字段。
搬移字段前应该先进行 getter 和 setter 函数的封装。
3. Extract Class(提炼类)
Q:某个类做了应该由两个类做的事。
A:建立一个新类,将相关的字段和函数从旧类搬移到新类。
类的体积过于庞大,改动类的部分字段时对其他字段毫无影响,子类化时发现一些特性与另一些特性的子类化方式不相同,此时应该考虑提炼类。
4. Inline Class(将类内联化)
Q:某个类没有做太多事情。
A:将这个类的所有特性搬移到另一个类中,然后移除原类。
与 Extract Class 相反,当一个类不再承担足够责任或不再有单独存在的理由时,挑选一个频繁使用这个类的用户类进行内联化。
5. Hide Delegate(隐藏“委托关系”)
Q:客户通过一个委托类来调用另一个对象。
A:在服务类上建立客户所需的所有函数,用以隐藏委托关系。
“封装”意味着每个对象都应该尽可能少了解系统的其他部分。
6. Remove Middle Man(移除中间人)
Q:某个类做了过多的简单委托动作。
A:让客户直接调用受托类。
与上一条相反,对于过度委托的中间类,每当客户想使用受托类的新特性,都必须在服务委托类上加入新的函数,此时应该直接让客户访问受托类。
7. Introduce Foreign Method(引入外加函数)
Q:你需要为提供服务的类增加一个函数,但你无法修改这个类。
A:在客户类中建立一个函数,并以第一参数形式传入一个服务类实例。
外加函数用于解决 SDK 中无法修改的类,增加更多功能,但是也会导致函数零散分布,耦合严重。
8. Introduce Local Extension(引入本地扩展)
Q:你需要为服务类提供一些额外函数,但你无法修改这个类。
A:建立一个新类,使它包含这些额外函数。让这个扩展品成为源类的子类或包装类。