重构读书笔记-12_1-Tease_Apart_Inheritance

重构第十二章

1.Tease Apart Inheritance(梳理并分解继承体系)

某个继承体系,同时承担两项责任。建立两个继承体系,并通过委托关系让其中一个可以调用另一个。

Example:

一开始Deal Class 只被用来显示单笔交易,后来添加了显示交易表格的功能,即建立一个ActiveDeal subclass,后需要被动交易表格即建立PassiveDeal subclass。


混乱的继承结构

之后我们使用Extract Class(提炼类)的方法提炼出一个PresentationStyle class用来表示[显示风格]

提炼类后的继承结构

此时,我们针对原继承体系下的每个subclass,建立PresentationStyle的一个subclasses,并将Deal class中用来保存PresentationStyle实体的instance变量初始化为适当的subclass实体。

之后使用Move Method和Move Field,将Deal subclasses中[与显示逻辑有关]的函数和变量搬移到PresentationStyle相应的subclasses中。

搬移函数后继承结构

之后,我们将摆脱[显示风格]中的主动(active)与被动[passive]区别,如下图。

分离继承系统

Conclusion:

继承是面向对象编程中的一个很好地特性,可以有效的减少重复代码的出现,使得程序结构更加的明晰。

但是混乱的继承体系是一个严重的问题,首先会导致重复代码,而且它的修改会变得困难,最终导致,你的代码将难以理解。

所以需要Tease Apart Inheritance(梳理并分解继承体系)来对既有系统中的继承体系进行梳理,保证继承系统的优良性,方便之后更加好的扩展。

注意

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

推荐阅读更多精彩内容

  • 一,重构,第一个案例 这一章作者先用一个影片出租程序的案例,来演示重构的过程 每个Customer顾客可以租多部M...
    高稷阅读 13,701评论 1 19
  • 阅读《重构》的笔记献上。 重构的定义 重构是在不改变软件可观察行为的前提下改善其内部结构。 重构的节奏 以微小的步...
    陈宇明阅读 13,984评论 13 64
  • 第一章 重构,第一个案例 如果你发现自己需要为程序添加一个特性,而代码结构使你无法很方便地达成目的,那就先重构那个...
    文浩读书阅读 4,355评论 0 0
  • chapter 1 重构,第一个案例 1.1 什么时候需要重构 需要为程序添加一个特性,但代码结构无法使自己方便的...
    VictorBXv阅读 6,288评论 0 1
  • 可以先看【推荐】:https://www.jianshu.com/p/d6ff54d72afb原文:http://...
    郭某人1阅读 5,859评论 0 0