重构第十二章
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(梳理并分解继承体系)来对既有系统中的继承体系进行梳理,保证继承系统的优良性,方便之后更加好的扩展。
注意
重构必须在有单元测试的情况下,保证之前的功能修改后不收影响。切记!!!
网友评论