在对象之间搬移特性
在对象的设计过程中,“决定把责任放在哪儿”即使不是最重要的事,也是最重要的事之一。类往往会因为承担过多责任而变得臃肿不堪。
Move Method(搬移函数)
- 现象: 程序中,有个函数与其所在类之外的另一个类进行更多交流:调用后者,或被后者调用
- 做法:在该函数最常引用的类中建立一个有着类似行为的新函数,将旧函数变成一个单纯的委托函数,或是将旧函数完全移除。
- 一个类有太多行为,或如果一个类与另一个类有太多合作而形成高度耦合,就要搬移函数,从而使系统中的类更简单,更干净利落地实现系统交付的任务
- 当目标类需要使用源类的特性时,有4种选择:
- 将这个特性也移到目标类;
- 建立或使用一个从目标类到源类的引用关系;
- 将源对象当做参数传给目标函数;
- 如果所需特性是个变量,将它作为参数传给目标函数;
- 如果被搬移函数调用了源函数中另一个函数,就必须把源对象传递给目标函数;如果需要源类的多个特性,也需将源对象传递给目标函数;如果目标函数需要太多源类特性,那最好分解目标函数,并将其中一部分移回源类。
Move Field (搬移字段)
- 现象:在你的程序中,某个字段被其所驻类之外的另一个类更多地用到。所谓“使用”可能是通过设置、取值函数间接进行的。
- 做法:在目标类新建一个字段,修改原字段的所有用户ÿ