好书推荐 好书速递 排行榜 读书文摘

重构

重构
作者:[美] Martin Fowler
译者:熊节
副标题:改善既有代码的设计
出版社:人民邮电出版社
出版年:2010-01
ISBN:9787115221704
行业:计算机
浏览数:176

内容简介

重构,一言以蔽之,就是在不改变外部行为的前提下,有条不紊地改善代码。多年前,正是本书原版的出版,使重构终于从编程高手们的小圈子走出,成为众多普通程序员日常开发工作中不可或缺的一部分。本书也因此成为与《设计模式》齐名的经典著作,被译为中、德、俄、日等众多语言,在世界范围内畅销不衰。

本书凝聚了软件开发社区专家多年摸索而获得的宝贵经验,拥有不因时光流逝而磨灭的价值。今天,无论是重构本身,业界对重构的理解,还是开发工具对重构的支持力度,都与本书最初出版时不可同日而语,但书中所蕴涵的意味和精华,依然值得反复咀嚼,而且往往能够常读常新。

......(更多)

作者简介

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

其他参编者——

Kent Beck 软件开发方法学的泰斗,极限编程的创始人。他是Three Rivers Institute公司总裁,也是Agitar Software的成员。

John Brant和Don Roberts The Refactory公司的创始人,Refactoring Browser (http://st-www.cs.illinois.edu/users/brant/Refactory/)的开发者,多年来一直从事研究重构的实践与理论。

William Opdyke 目前在朗讯贝尔实验室工作,他写的关于面向对象框架的博士论文是重构方面的第一篇著名文章。

......(更多)

目录

第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

......(更多)

读书文摘

只有深刻认识不确定性,才能真正理解信息化。对不确定性的恐惧是人类社会认知的动力,不确定性源于信息约東条件下人们有限的认知能力。在任何时代,化解对不确定性恐惧的三步曲是对客观世界的理解、预测、控制,从远古到现代,人类一直在努力提高认识世界的水平,以观察世界、理解规律、指导实践,来解释过去、阐明现在、预测未来,终极目的在于提升认知水平以提高驾驭不确定性的能力。

回顾工业革命近三百多年发展史,每次技术变革都将带来社会生产过程确定性的大幅提高,从提高动力输出确定性的内燃机,到提高产品精度确定性的可编程逻辑控制器,再到提高企业管理运营确定性的软件系统,确定性是不变的追求。而每次确定性的提升都伴随着更大范围不确定性的涌现,不确定性是永恒的主题。

It is better to write and run incomplete tests than not to run complete tests.

to make the software easier to understand and modify.

......(更多)

猜你喜欢

点击查看