重构读书笔记-12_4-Extract_Hierarchy

重构第十二章

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。

注意

重构必须在有单元测试的情况下,保证之前的功能修改后不收影响。切记!!!
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • chapter 1 重构,第一个案例 1.1 什么时候需要重构 需要为程序添加一个特性,但代码结构无法使自己方便的...
    VictorBXv阅读 6,286评论 0 1
  • 阅读《重构》的笔记献上。 重构的定义 重构是在不改变软件可观察行为的前提下改善其内部结构。 重构的节奏 以微小的步...
    陈宇明阅读 13,984评论 13 64
  • 一,重构,第一个案例 这一章作者先用一个影片出租程序的案例,来演示重构的过程 每个Customer顾客可以租多部M...
    高稷阅读 13,701评论 1 19
  • 如果尿布臭了,就换掉它。 一. Duplicated Code(重复代码) 如果你在一个以上的地点看到相同的程序结...
    nimw阅读 5,449评论 0 2
  • 亲爱的姐姐 今天是你出嫁的日子 当我用手中的烟头点燃礼炮 当我看着你披上红红的盖头 当我跟着你走进喧闹的礼堂 心里...
    闲狐兔阅读 1,950评论 0 2