重构.改善既有代码的设计12大型重构

Posted aoyihuashao

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了重构.改善既有代码的设计12大型重构相关的知识,希望对你有一定的参考价值。

12、大型重构

这是一个庞大的工程,可能需要几个月。

在这个过程中,你应该根据需要安排自己的工作,只在需要添加新功能或修补错误 时才进行重构。 
你不必一开始就完成整个系统的重构;重构程度只要能满足其他任务的需要就行了。反正明天你还可以回来重构。

进行大规模重构时,有必要为整个开发团队建立共识;这是小型重构所不需要的。 
大型重构为许许多多的修改指定了方向。 
整个团队都必须意识到:有一个大型重构正在进行,每个人都应该相应地安排自己的行动。

下面是4个例子,老实说,这4个例子并没有指导我什么新的东西,因为这些我已经熟练应用过了。

 

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

场景:某个继承体系(inheritance hierarchy )同时承担两项责任。 
方案:建立两个继承体系,并通过委托关系(delegation)让其中一个可以调用另一个。 
  其似说白了,就是分离出一个变化方向,只是从一个继承体系分离出来,形成另一个继承体系,然后再聚合回来。

有一个模式是讲这个问题的:桥接模式。

 

Convert Procedural Design to Objects(将过程化设计转化为对象设计)

 

Separate Domain from Presentation(将领域和表述/显示分离)

就是说的前后端分离。

 

Extract Hierarchy(提炼继承体系)

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

本质是这个类过大了,它包含了多个分支,本应该属于多个子类的动作被用条件分割在了父类里。

 

 

以上是关于重构.改善既有代码的设计12大型重构的主要内容,如果未能解决你的问题,请参考以下文章

重构·改善既有代码的设计.04之重构手法(下)完结

重构·改善既有代码的设计.01

《重构——改善既有代码的设计》PDF下载

《重构——改善既有代码的设计》PDF下载

重构:改善既有代码的设计读书笔记——开篇

实践提高《重构改善既有代码的设计第2版》PDF中文+PDF英文+对比分析