《重构》读书笔记

《重构》学习笔记(09)-- 处理概括关系

2019-10-20  本文已影响0人  若隐爱读书

概括关系(Generalization),就是平时所说的继承关系。继承是面向对象的语言的重要特性,如何高效科学的使用继承,是重构的关键课题之一。

Pull Up Field(字段上移)

重构前
重构后

如果各子类是分别开发的,或者是在重构过程中组合起来的。你常常会发现他们拥有重复特性,特别是字段更容易重复。这时候,使用字段上移,将重复字段归类到超类中去。
这种重构的做法为:

Pull Up Method(函数上移)

类似于字段上移,如果一个函数在各个子类中有完全相同的结果,那么将该函数移到超类中。


重构前
重构后

这种重构的做法:

Pull Up Constructor Body(构造函数本体上移)

你再各个子类中拥有一些构造函数,它们的本体几乎完全一致。在超类中新建一个构造函数,并在子类构造函数中调用它。

class Manager extends Employee ...
  public Manager(String name,String id,int grade){
     _name = name;
    _id = id;
    _grade = grade;
}

重构为

public Manager(String name,String id,int grade){
   super(name,id); 
   _grade = grade;
}

这种重构方法的做法

Pull Down Method(函数下移)

如果超类中某个函数只与部分(而非全部)子类有关。将这个函数移到相关的那些子类去。


重构前
重构后

做法

Pull Down Field(字段下移)

超类中某个字段只与部分(而非全部)子类用到。将这个字段移到需要它的那些子类去。


重构前
重构后

做法

Extract Subclass(提炼子类)

类中的某些特性只被某些(而非全部)实例用到。新建一个子类,将上面所说的那一部分特性移到子类中。


重构前
重构后

做法

Extract Superclass(提炼超类)

两个类有相似特性。为这两个类建立一个超类,将相同特性移至超类。


重构前
重构后

做法

Extract Interface(提炼接口)

若干客户使用类接口中的同一子集,或者两个类的接口有部分相同。将相同的子集提炼到一个独立接口中。


重构前
重构后

做法

Collapse Hierarchy(折叠继承体系)

超类和子类之间无太大区别。将它们合为一体。


重构前
重构后

做法

Form TemPlate Method(塑造模板函数)

你有一些子类,其中相应的某些函数以相同的执行顺序执行类似的操作,但各个操作的细节上有所不同。将这些操作分别放进独立函数中,并保持它们都有相同的签名,于是原函数也就变得相同了。然后将原函数上移至超类。


重构前
重构后

做法

Replace Inheritance with Delegation(以委托取代继承)

某个子类只使用超类接口中的一部分。或是根本不需要继承而来的数据。在子类中新建一个字段用以保存超类,调整子类函数,令它改而委托超类;然后去掉两者之间的继承关系。

重构前
重构后

做法

Replace Delegation with Inheritance(以继承取代委托)

你在两个类之间使用委托关系,并经常为整个接口编写许多极简单的委托关系。


重构前
重构后

做法

上一篇 下一篇

猜你喜欢

热点阅读