編輯推薦
軟體工程領域的超級經典巨著,與另一巨著《設計模式》並稱"軟工雙雄",全美銷量超過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