请输入您要查询的百科知识:

 

词条 重构-改善既有代码的设计
释义

《重构:改善既有代码的设计》清晰地揭示了重构的过程,解释了重构的原理和最佳实践方式,并给出了何时以及何地应该开始挖掘代码以求改善。书中给出了70多个可行的重构,每个重构都介绍了一种经过验证的代码变换手法的动机和技术。《重构:改善既有代码的设计》提出的重构准则将帮助你一次一小步地修改你的代码,从而减少了开发过程中的风险。《重构:改善既有代码的设计》适合软件开发人员、项目管理人员等阅读,也可作为高等院校计算机及相关专业师生的参考读物。

基本信息

重构-改善既有代码的设计

作 者: (美)福勒 著;

侯捷 熊节 译

出 版 社: 中国电力出版社出版时间: 2003-8-1

字 数: 540000

版 次: 1版1次

页 数: 431

印刷时间: 2003/08/01

印 次:

纸 张: 胶版纸

I S B N : 9787508315546

包 装: 平装

编辑推荐

软件工程领域的超级经典巨著,与另一巨著《设计模式》并称"软工双雄",全美销量超过100000册,亚马逊书店五星书。

在本书中,作者Martin Fowler充分展示了何处可能需要重构,以及如何将不好的设计改造为良好的设计。

当对象技术成为老生常谈之后——尤其在Java编程语言之中,新的问题也在软件开发社区中浮现了出来。缺乏经验的开发人员完成了大量粗劣设计,获得的程序不但缺乏效率,也难以维护和扩展。渐渐地,软件系统专家发现,与这些沿袭下来的、质量不佳的程序共处,是多么艰难。对象专家运用许多技术来改善既有程序的结构完美性与性能,已有数年之久。

内容简介

Martin Fowler和本书另几位作者清楚揭示了重构过程,他们为面向对象软件开发所做的贡献,难以衡量。本书解释重构的原理(principles)和最佳实践方式(best practices),并指出何时何地你应该开始挖掘你的代码以求改善。

本书的核心是一份完整的重构名录(catalog of refactoring),其中每一项都介绍一种经过实证的代码变换手法(code transformation)的动机和技术。某些项目如Extract Method和Move Field看起来可能很浅显,但不要掉以轻心,因为理解这类技术正是有条不紊地进行重构的关键。本书所提的这些重构准则将帮助你一次一小步地修改你的代码,这就减少了过程中的风险。很快你就会把这些重构准则和其名称加入自己的开发词典中,并且朗朗上口。

作者简介

Martin Fowler是一位独立咨询顾问,他运用对象技术解决企业问题已经超过十年。他的顾问领域包括健康管理、金融贸易,以及法人财务。他的客户包括Chrysler,Citibank,UK National Health Service,AndersenConsulting,NetscapeCommunications。此外Fowler也是objects、UML、patterns技术的一位合格讲师,他是《AnalysisPatterns》和《UMLDistilled》的作者。

作者:(美国)福勒(Martin Fowler) Martin Fowler,世界软件开发大师,在面向对象分析设计、UML、模式、XP和重构等领域都有卓越贡献,现为著名软件开发咨询公司ThoughtWorks的首席科学家。他的多部著作《分析模式》、《UML精粹》和《企业应用架构模式》等都已经成为脍炙人口的经典。

译者:熊节

熊节,ThoughtWorks中国公司的高级咨询师、架构师和项目经理,在大型企业应用及互联网应用的架构和管理方面拥有丰富经验。作为敏捷方法学顾问和重构专家,他拥有在各种技术平台、编程语言、软件形态的项目中实施重构的丰富经验,并曾主持极具挑战性的超大规模电信软件系列重构工作。

目录

第1章 重构,第一个案例1

1.1 起点1

1.2 重构的第一步7

1.3 分解并重组statement()8

1.4 运用多态取代与价格相关的条件逻辑34

1.5 结语52

第2章 重构原则53

2.1 何谓重构53

2.2 为何重构55

2.3 何时重构57

2.4 怎么对经理说60

2.5 重构的难题62

2.6 重构与设计66

2.7 重构与性能69

2.8 重构起源何处71

第3章 代码的坏味道75

3.1 DuplicatedCode(重复代码)76

3.2 LongMethod(过长函数)76

3.3 LargeClass(过大的类)78

3.4 LongParameterList(过长参数列)78

3.5 DivergentChange(发散式变化)79

3.6 ShotgunSurgery(霰弹式修改)80

3.7 FeatureEnvy(依恋情结)80

3.8 DataClumps(数据泥团)81

3.9 PrimitiveObsession(基本类型偏执)81

3.10 SwitchStatements(switch惊悚现身)82

3.11 ParallelInheritanceHierarchies(平行继承体系)83

3.12 LazyClass(冗赘类)83

3.13 SpeculativeGenerality(夸夸其谈未来性)83

3.14 TemporaryField(令人迷惑的暂时字段)84

3.15 MessageChains(过度耦合的消息链)84

3.16 MiddleMan(中间人)85

3.17 InappropriateIntimacy(狎昵关系)85

3.18 AlternativeClasseswithDifferentInterfaces(异曲同工的类)85

3.19 IncompleteLibraryClass(不完美的库类)86

3.20 DataClass(纯稚的数据类)86

3.21 RefusedBequest(被拒绝的遗赠)87

3.22 Comments(过多的注释)87

第4章 构筑测试体系89

4.1 自测试代码的价值89

4.2 JUnit测试框架91

4.3 添加更多测试97

第5章 重构列表103

5.1 重构的记录格式103

5.2 寻找引用点105

5.3 这些重构手法有多成熟106

第6章 重新组织函数109

6.1 ExtractMethod(提炼函数)110

6.2 InlineMethod(内联函数)117

6.3 InlineTemp(内联临时变量)119

6.4 ReplaceTempwithQuery(以查询取代临时变量)120

6.5 IntroduceExplainingVariable(引入解释性变量)124

6.6 SplitTemporaryVariable(分解临时变量)128

6.7 RemoveAssignmentstoParameters(移除对参数的赋值)131

6.8 ReplaceMethodwithMethodObject(以函数对象取代函数)135

6.9 SubstituteAlgorithm(替换算法)139

第7章 在对象之间搬移特性141

7.1 MoveMethod(搬移函数)142

7.2 MoveField(搬移字段)146

7.3 ExtractClass(提炼类)149

7.4 InlineClass(将类内联化)154

7.5 HideDelegate(隐藏“委托关系”)157

7.6 RemoveMiddleMan(移除中间人)160

7.7 IntroduceForeignMethod(引入外加函数)162

7.8 IntroduceLocalExtension(引入本地扩展)164

第8章 重新组织数据169

8.1 SelfEncapsulateField(自封装字段)171

8.2 ReplaceDataValuewithObject(以对象取代数据值)175

8.3 ChangeValuetoReference(将值对象改为引用对象)179

8.4 ChangeReferencetoValue(将引用对象改为值对象)183

8.5 ReplaceArraywithObject(以对象取代数组)186

8.6 DuplicateObservedData(复制“被监视数据”)189

8.7 ChangeUnidirectionalAssociationtoBidirectional(将单向关联改为双向关联)197

8.8 ChangeBidirectionalAssociationtoUnidirectional(将双向关联改为单向关联)200

8.9 ReplaceMagicNumberwithSymbolicConstant(以字面常量取代魔法数)204

8.10 EncapsulateField(封装字段)206

8.11 EncapsulateCollection(封装集合)208

8.12 ReplaceRecordwithDataClass(以数据类取代记录)217

8.13 ReplaceTypeCodewithClass(以类取代类型码)218

8.14 ReplaceTypeCodewithSubclasses(以子类取代类型码)223

8.15 ReplaceTypeCodewithState/Strategy(以State/Strategy取代类型码)227

8.16 ReplaceSubclasswithFields(以字段取代子类)232

第9章 简化条件表达式237

9.1 DecomposeConditional(分解条件表达式)238

9.2 ConsolidateConditionalExpression(合并条件表达式)240

9.3 ConsolidateDuplicateConditionalFragments(合并重复的条件片段)243

9.4 RemoveControlFlag(移除控制标记)245

9.5 ReplaceNestedConditionalwithGuardClauses(以卫语句取代嵌套条件表达式)250

9.6 ReplaceConditionalwithPolymorphism(以多态取代条件表达式)255

9.7 IntroduceNullObject(引入Null对象)260

9.8 IntroduceAssertion(引入断言)267

第10章 简化函数调用271

10.1 RenameMethod(函数改名)273

10.2 AddParameter(添加参数)275

10.3 RemoveParameter(移除参数)277

10.4 SeparateQueryfromModifier(将查询函数和修改函数分离)279

10.5 ParameterizeMethod(令函数携带参数)283

10.6 ReplaceParameterwithExplicitMethods(以明确函数取代参数)285

10.7 PreserveWholeObject(保持对象完整)288

10.8 ReplaceParameterwithMethods(以函数取代参数)292

10.9 IntroduceParameterObject(引入参数对象)295

10.10 RemoveSettingMethod(移除设值函数)300

10.11 HideMethod(隐藏函数)303

10.12 ReplaceConstructorwithFactoryMethod(以工厂函数取代构造函数)304

10.13 EncapsulateDowncast(封装向下转型)308

10.14 ReplaceErrorCodewithException(以异常取代错误码)310

10.15 ReplaceExceptionwithTest(以测试取代异常)315

第11章 处理概括关系319

11.1 PullUpField(字段上移)320

11.2 PullUpMethod(函数上移)322

11.3 PullUpConstructorBody(构造函数本体上移)325

11.4 PushDownMethod(函数下移)328

11.5 PushDownField(字段下移)329

11.6 ExtractSubclass(提炼子类)330

……

第12章 大型重构359

第13章 重构,复用与现实379

第14章 重构工具401

第15章 总结409

参考书目413

要点列表417

索引419

书摘

序言

第一次听到“重构”这个词,是在2001年10月。在当时,它的思想足以令我感到震撼。软件自有其美感所在。软件工程希望建立完美的需求与设计,按照既有的规范编写标准划一的代码,这是结构的美;快速迭代和RAD颠覆“全知全能”的神话,用近乎刀劈斧砍(crack)的方式解决问题,在混沌的循环往复中实现需求,这是解构的美;而Kent Beck与Martin Fowler两人站在一起,以XP那敏捷而又严谨的方法论演绎了重构的美——我不知道是谁最初把refactoring一词翻译为“重构”,或许无心插柳,却成了点睛之笔。

我一直是设计模式的爱好者。曾经在我的思想中,软件开发应该有一个“理想国”——当然,在这个理想国维持着完美秩序的,不是哲学家,而是模式。设计模式给我们的,不仅仅是一些具体问题的解决方案,更有追求完美“理型”的渴望。但是,Joshua Kerievsky在那篇著名的《模式与XP》(收录于《极限编程研究》一书)中明白地指出:在设计前期使用模式常常导致过度工程(over-engineering)。这是一个残酷的现实,单凭对完美的追求无法写出实用的代码,而“实用”是软件压倒一切的要素。从一篇《停止过度工程》开始,Kerievsky撰写了“Refactoring to Patterns”系列文章。这位犹太人用他民族性的睿智头脑,敏锐地发现了软件的后结构主义道路。而让设计模式在飞速变化的网络时代重新闪现光辉的,又是重构的力量。

在一篇流传甚广的帖子里,有人把《重构》与《设计模式》并列为“Java行业的圣经”。在我看来这种并列其实并不准确。实际上,尽管我如此喜爱这本《重构》,但自从完成翻译之后,就再也没有读过它。不,不是因为我已经对它烂熟于心,而是因为重构已经变成了我的另一种生活方式,变成了我每天的“面包与黄油”,变成了我们整个团队的空气与水,以至于无需再到书中寻找任何“神谕”。而《设计模式》,我倒是放在手边时常翻阅,因为总是记得不那么真切。

文摘

现在,重构的处境也是如此。我们知道重构的好处,我们知道重构可以给我们的工作带来立竿见影的改变。但是我们还没有获得足够的经验,我们还看不到它的局限性。

这一节比我希望的要短。暂且如此吧。随着更多人学会重构技巧,我们也将对它有更多了解。对你而言这意味着:虽然我坚决认为你应该尝试一下重构,获得它所提供的利益,但与此同时,你也应该时时监控其过程,注意寻找重构可能引入的问题。请让我们知道你所遭遇的问题。随着对重构的了解日益增多,我们将找出更多解决办法,并清楚知道哪些问题是真正难以解决的。数据库

重构经常出问题的一个领域就是数据库。绝大多数商用程序都与它们背后的数据库结构紧密耦合在一起,这也是数据库结构如此难以修改的原因之一。另一个原因是数据迁移(migration)。就算你非常小心地将系统分层,将数据库结构和对象模型间的依赖降至最低,但数据库结构的改变还是让你不得不迁移所有数据,这可能是件漫长而烦琐的工作。

在非对象数据库中,解决这个问题的办法之一就是:在对象模型和数据库模型之间插入一个分隔层,这就可以隔离两个模型各自的变化。升级某一模型时无需同时升级另一模型,只需升级上述的分隔层即可。这样的分隔层会增加系统复杂度,但可以给你带来很大的灵活度。如果你同时拥有多个数据库,或如果数据库模型较为复杂使你难以控制,那么即使不进行重构,这分隔层也是很重要的。

你无需一开始就插入分隔层,可以在发现对象模型变得不稳定时再产生它,这样你就可以为你的改变找到最好的平衡点。

对开发者而言,对象数据库既有帮助也有妨碍。某些面向对象数据库提供不同版本的对象之间的自动迁移功能,这减少了数据迁移时的工作量,但还是会损失一定时间。如果各数据库之间的数据迁移并非自动进行,你就必须自行完成迁移工作,这个工作量可是很大的。这种情况下你必须更加留神类中的数据结构变化。你仍然可以放心将类的行为转移过去,但转移字段时就必须格外小心。数据尚未被转移前你就得先运用访问函数造成“数据已经转移”的假象。一旦你确定知道数据应该放在何处,就可以一次性地将数据迁移过去。

随便看

 

百科全书收录4421916条中文百科知识,基本涵盖了大多数领域的百科知识,是一部内容开放、自由的电子版百科全书。

 

Copyright © 2004-2023 Cnenc.net All Rights Reserved
更新时间:2025/1/11 3:50:03