重构-改善既有代码的设计(十一)--处理归纳关系

前言

有一批重构手法专门用来处理归纳关系(即继承关系),主要是将函数上下移动于继承体系之中字段上移和方法上移都用于将特性向继承体系的上端移动,字段下移和方法下移则将特性向继承体系的下端移动。构造函数比较难以向上拉动,所以专门有一个构造函数本体上移处理它,通常不会将构造函数往下推,由于以工厂函数取代构造函数一般更管用。java

字段上移

问题

两个子类拥有相同的字段函数

方法

将该字段上移继承

动机

既然是相同字段就应该放在父类中接口

函数上移

问题

有些函数,在各个子类中产生彻底相同的效果模板

方法

将该函数移至超类泛型

动机

相同效果的方法应该能够作成一个方法吧。重构

构造函数本体上移

问题

在各个子类中拥有一些构造函数,他们的本体几乎彻底一致构造函数

方法

在超类中新建一个构造函数,并在子类构造函数中调用它方法

动机

又是重复代码。。。数据

函数下移

问题

超类中的某个函数只与部分(而非所有)子类有关

方法

将这个函数移到相关的子类去

动机

这个就是依恋关系。直接迁移函数

字段下移

问题

超类中的某个字段只被部分(而非所有)子类用到

方法

将这个字段移到须要它的那些子类去

动机

这个就是依恋关系。直接迁移字段

提炼子类

问题

类中的某些特性只被某些(而非所有)实例用到

方法

新建一个子类,将上面所说的那一部分特性移到子类中

动机

说明这个类并非只作一件事。并且还比较重。须要拆分

提炼超类

问题

两个类有类似的特性

方法

为这两个类创建一个超类,将相同特性移至超类

动机

用父类来封装类似的特性,用子类来新特性

# 提炼接口

问题

若干客户使用类接口中的同一子集,或者两个类的接口有部分相同

方法

将相同的子集提炼到一个独立的接口中

动机

同上

折叠继承体系

问题

超类和子类之间没有太大的区别

方法

将它们合为一体

动机

根据具体状况而用

塑造模板函数

问题

有一些子类,其中相应的某些函数以相同顺序执行相似的操做,但各个操做的细节上有所不一样

方法

将这些操做分别放进独立函数中,并操持它们都有相同的签名,因而原函数也就变得相同了,而后将原函数上移至超类。

动机

好比java的泛型,就是模板函数,可以大大减小代码重复

以委托取代继承

问题

某个子类只使用超类接口中的一部分,或是根本不须要继承而来的数据

方法

在子类中新建一个字段用以保存超类,调整子类函数,令它改而委托超类,而后去掉二者之间的继承关系。

动机

若是只使用方法的话,能够这样使用

以继承取代委托

问题

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

方法·

让委托类继承受托类

动机

太简单的委托是没有必要的。只会增长代码量。

相关文章
相关标签/搜索