美文网首页
重构读书笔记-12_1-Tease_Apart_Inherita

重构读书笔记-12_1-Tease_Apart_Inherita

作者: MR_Model | 来源:发表于2019-08-12 09:24 被阅读0次

    重构第十二章

    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(梳理并分解继承体系)来对既有系统中的继承体系进行梳理,保证继承系统的优良性,方便之后更加好的扩展。

    注意

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

    相关文章

      网友评论

          本文标题:重构读书笔记-12_1-Tease_Apart_Inherita

          本文链接:https://www.haomeiwen.com/subject/lvhyjctx.html