重构读书笔记-12_4-Extract_Hierarchy

2019-08-15  本文已影响0人  MR_Model

重构第十二章

4.Extract Hierarchy(提炼继承体系)

你有某个class做了太多(过多)工作,其中一部分是以大量条件式完成的。建立继承体系,以一个subclass表示一种特殊情况。

Example:

我们以一个电费计算程序为例,这个程序有两个classes表示[消费者]的Customer和表示[计费方案]的BillingScheme。

BillingScheme使用道亮逻辑来计算不同情况下的费用:冬季和夏季的电价不同,私宅用电、小型企业用电、社会救济(包括残障人士)用电价格。


Customer和BillingScheme的关系

我们针对这种编译建立一个subclass-DisabilityBillingScheme对象,表示残障人士计算规则。


建立DisabilityBillingScheme

实施本项重构时,我们使用Extract Method(提炼方法)和Decompose Conditional(分解条件式)之类的方法。针对class中[可能变化]和[始终不变的部分分开]。

之后我们可以建立其他不同的subclass,只需要使用相同的签名式,这样会使得这个系统结构趋于稳定,使我们更容易添加后续更多变异。

Conclusion:

你可能需要本项策略,将冗杂的class分解成细小的subclass。不过,请注意只有当条件逻辑在对象整个生命周期保持不变,本项重构才适用,否则,应该适用Extract class。

注意

重构必须在有单元测试的情况下,保证之前的功能修改后不收影响。切记!!!
上一篇 下一篇

猜你喜欢

热点阅读