重构第十二章
4.Extract Hierarchy(提炼继承体系)
你有某个class做了太多(过多)工作,其中一部分是以大量条件式完成的。建立继承体系,以一个subclass表示一种特殊情况。
Example:
我们以一个电费计算程序为例,这个程序有两个classes表示[消费者]的Customer和表示[计费方案]的BillingScheme。
BillingScheme使用道亮逻辑来计算不同情况下的费用:冬季和夏季的电价不同,私宅用电、小型企业用电、社会救济(包括残障人士)用电价格。
我们针对这种编译建立一个subclass-DisabilityBillingScheme对象,表示残障人士计算规则。
实施本项重构时,我们使用Extract Method(提炼方法)和Decompose Conditional(分解条件式)之类的方法。针对class中[可能变化]和[始终不变的部分分开]。
之后我们可以建立其他不同的subclass,只需要使用相同的签名式,这样会使得这个系统结构趋于稳定,使我们更容易添加后续更多变异。
Conclusion:
你可能需要本项策略,将冗杂的class分解成细小的subclass。不过,请注意只有当条件逻辑在对象整个生命周期保持不变,本项重构才适用,否则,应该适用Extract class。
注意
重构必须在有单元测试的情况下,保证之前的功能修改后不收影响。切记!!!