版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)
文檔簡介
1、淺談軟件重構(gòu)與性能優(yōu)化2009.08參考書目重構(gòu):改善既有代碼的設(shè)計作者:MARTIN FOWLER譯者:侯捷 熊節(jié)什么是重構(gòu)? 重構(gòu)(Refactoring):在不改變軟件的功能和外部可見性的情況下,為了改善軟件的結(jié)構(gòu),提高清晰性、可擴(kuò)展性和可重用性而對軟件進(jìn)行的改造,對代碼內(nèi)部的結(jié)構(gòu)進(jìn)行優(yōu)化。2008-04-02為什么要重構(gòu)? 改進(jìn)軟件的設(shè)計 提高代碼質(zhì)量,可維護(hù)性 Refactoring幫助盡早的發(fā)現(xiàn)錯誤(Defects)Refactoring可以提高提高開發(fā)速度 2008-04-02什么時候需要重構(gòu) ?在開始增加一個新的功能之前 在修復(fù)一個錯誤的時候 在做Code Review的時候
2、2008-04-02何時不應(yīng)該重構(gòu) ?代碼太混亂,設(shè)計完全錯誤 明天是DeadLine 重構(gòu)的工作量顯著的影響Estimate 2008-04-02重構(gòu)流程 讀懂代碼(包括測試?yán)哟a) 進(jìn)行重構(gòu) 運行所有的Unit Tests 2008-04-02重構(gòu)與設(shè)計 重構(gòu)與設(shè)計是互補(bǔ)的,程序應(yīng)該是先設(shè)計,而在開始編碼后,設(shè)計上的不足可以用重構(gòu)來彌補(bǔ).設(shè)計應(yīng)該是適度的設(shè)計,而不必過度的設(shè)計.如果能很容易的通過重構(gòu)來適應(yīng)需求的變化,那么就不必過度的設(shè)計,當(dāng)需求改變時再重構(gòu)代碼 。2008-04-02重構(gòu)與性能 時間預(yù)算法 持續(xù)關(guān)注法良好的分解方式 2008-04-02時間預(yù)算法 在設(shè)計時就對程序花費的時
3、間進(jìn)行預(yù)算,通常用于性能要求極高的實時系統(tǒng).普通的企業(yè)應(yīng)用程序一般對性能要求不高.只要不太慢就可以了 。2008-04-02持續(xù)關(guān)注法 要求程序員在任何時間都要設(shè)法保持系統(tǒng)的高性能.這個方法有個缺陷,就是大部分的程序90%的優(yōu)化工作都是白費勁,這樣會浪費大量的時間 。2008-04-02良好的分解方式 這個方式是在開發(fā)程序階段不對性能投以任何關(guān)注,直到進(jìn)入性能優(yōu)化階段,再分析程序中性能差的程序,然后對這些程序進(jìn)分解,查出性能差的程序,進(jìn)行優(yōu)化。 2008-04-02代碼編寫的22宗罪(BadSmellsinCode ) (1)DuplicatedCode(重復(fù)的代碼)(2)LongMethod
4、(過長函數(shù))(3)LargeClass(過大類)(4)LongParameterList(過長參數(shù)列)(5)DivergentChange(發(fā)散式變化)(6)ShortgunSurgery(霰彈式修改)(7)FeatureEnvy(依戀情結(jié))(8)DataClumps(數(shù)據(jù)泥團(tuán))(9)PrimitiveObsession(基本型別偏執(zhí))(10)SwitchStatements(switch驚悚現(xiàn)身)(11)ParallelInheritanceHierarchies(平行繼承體系) 2008-04-02(12)LazyClass(冗贅類)(13)SpeculativeGenerality(夸夸
5、其談未來性)(14)TemporaryField(令人迷惑的暫時值域)(15)MessageChains(過度耦合的消息鏈)(16)MiddleMan(中間轉(zhuǎn)手人)(17)InappropriateIntimacy(狎昵關(guān)系)(18)AlternativeClasseswithDifferentInterfaces(異曲同工的類)(19)IncompleteLibraryClass(不完善的程序庫類)(20)DataClass(純稚的數(shù)據(jù)類)(21)RefusedBequest(被拒絕的遺贈)(22)Comments(過多的注釋) 2008-04-02建立測試體系(BuildingTests)
6、 (1)自我測試碼(Self-testingCode)的價值(2)可以參考JUnit測試框架(TestingFramework)(3)添加更多測試 2008-04-02重新組織你的函數(shù)(ComposingMethods) (1)ExtractMethod(提煉函數(shù))(2)InlineMethod(將函數(shù)內(nèi)聯(lián)化)(3)InlineTemp(將臨時變量內(nèi)聯(lián)化)(4)ReplaceTempWithQuery(以查詢?nèi)〈R時變量)(5)IntroduceExplainingVariable(引入解釋性變量)(6)SplitTemporaryVariable(剖解臨時變量)(7)RemoveAssign
7、mentstoParameters(移除對參數(shù)的賦值動作)(8)ReplaceMethodwithMethodObject(以函數(shù)對象取代函數(shù))(9)SubstituteAlgorithm(替換你的算法) 2008-04-02ExtractMethod(提煉函數(shù))void printOwing() /print bannerSystem.out.println(“*”);System.out.println(“Banner”);System.out.println(“*”);/print detailsSystem.out.println (name: + _name); System.out
8、.println (amount + getOutstanding(); void printOwing() printBanner(); printDetails(getOutstanding(); Void printBanner() /print banner System.out.println(“*”); System.out.println(“Banner”); System.out.println(“*”);void printDetails (double outstanding) System.out.println (name: + _name); System.out.p
9、rintln (amount + outstanding); 2008-04-02InlineMethod(將函數(shù)內(nèi)聯(lián)化)int getRating() return (moreThanFiveLateDeliveries() ? 2 : 1; boolean moreThanFiveLateDeliveries() return _numberOfLateDeliveries 5; int getRating() return (_numberOfLateDeliveries 5) ? 2 : 1; 2008-04-02InlineTemp(將臨時變量內(nèi)聯(lián)化)double basePrice
10、 = anOrder.basePrice(); return (basePrice 1000) ;return (anOrder.basePrice() 1000) ;2008-04-02ReplaceTempWithQuery(以查詢?nèi)〈R時變量) double basePrice = _quantity * _itemPrice; if (basePrice 1000) return basePrice * 0.95; else return basePrice * 0.98; if (basePrice() 1000) return basePrice() * 0.95; else re
11、turn basePrice() * 0.98; double basePrice() return _quantity * _itemPrice; 2008-04-02IntroduceExplainingVariable(引入解釋性變量) if ( (platform.toUpperCase().indexOf(MAC) -1) & (browser.toUpperCase().indexOf(IE) -1) & wasInitialized() & resize 0 ) / do something final boolean isMacOs = atform.toUpperCase()
12、.indexOf(MAC) -1; final boolean isIEBrowser = browser.toUpperCase().indexOf(IE) -1; final boolean wasResized = resize 0; if (isMacOs & isIEBrowser & wasInitialized() & wasResized) / do something 2008-04-02RemoveAssignmentstoParameters(移除對參數(shù)的賦值動作) int discount (int inputVal, int quantity, int yearToD
13、ate) if (inputVal 50) inputVal -= 2; int discount (int inputVal, int quantity, int yearToDate) int result = inputVal; if (inputVal 50) result -= 2; 如果參數(shù)是Object,容易誤賦值。采用final來防止誤用參數(shù)2008-04-02ReplaceMethodwithMethodObject(以函數(shù)對象取代函數(shù)) class Order. double price() double primaryBasePrice; double secondary
14、BasePrice; double tertiaryBasePrice; / long computation; . 或者可以采用static method2008-04-02SubstituteAlgorithm(替換你的算法)String foundPerson(String people) for (int i = 0; i people.length; i+) if (peoplei.equals (Don) return Don; if (peoplei.equals (John) return John; if (peoplei.equals (Kent) return Kent;
15、 return ; String foundPerson(String people) List candidates = Arrays.asList(new String Don, John, Kent); for (int i=0; ipeople.length; i+) if (candidates.contains(peoplei) return peoplei; return ; 2008-04-02在對象之間移動特性(MovingFeaturesBetweenObjects) (1)MoveMethod(搬移函數(shù))(2)MoveField(搬移值域)(3)ExtractClass(
16、提煉類)(4)InlineClass(將類內(nèi)聯(lián)化)(5)HideDelegate(隱藏委托關(guān)系)(6)RemoveMiddleMan(移除中間人)(7)IntroduceForeignMethod(引入外加函數(shù))(8)IntroduceLocalExtension(引入本地擴(kuò)展) 2008-04-02MoveMethod(搬移函數(shù))2008-04-02MoveField(搬移值域)2008-04-02ExtractClass(提煉類)2008-04-02InlineClass(將類內(nèi)聯(lián)化)2008-04-02HideDelegate(隱藏委托關(guān)系)2008-04-02RemoveMiddleM
17、an(移除中間人)2008-04-02IntroduceForeignMethod(引入外加函數(shù))2008-04-02IntroduceLocalExtension(引入本地擴(kuò)展)2008-04-02重新組織你的數(shù)據(jù)(OrganizingData) (1)SelfEncapsulateField(自封裝值域)(2)ReplaceDataValuewithObject(以對象取代數(shù)據(jù)值)(3)ChangeValuetoReference(將實值對象改為引用對象)(4)ChangeReferencetoValue(將引用對象改為實值對象)(5)ReplaceArraywithObject(以對象取
18、代數(shù)組)(6)DuplicateObservedData(復(fù)制被監(jiān)視數(shù)據(jù))(7)ChangeUnidirectionalAssociationtoBidirectional(將單向關(guān)聯(lián)改為雙向)(8)ChangeBidirectionalAssociationtoUnidirectional(將雙向關(guān)聯(lián)改為單向) 2008-04-02(9)ReplaceMagicNumberwithSymbolicConstant(以符號常量/字面常量取代魔法數(shù))(10)EncapsulateField(封裝值域)(11)EncapsulateCollection(封裝群集)(12)ReplaceRecord
19、withDataClass(以數(shù)據(jù)類取代記錄)(13)ReplaceTypeCodewithClass(以類取代型別碼)(14)ReplaceTypeCodewithSubclasses(以子類取代型別碼)(15)ReplaceTypeCodewithState/Strategy(以State/Strategy取代型別碼)(16)ReplaceSubclasswithFields(以值域取代子類) 2008-04-02SelfEncapsulateField(自封裝值域) 2008-04-02ReplaceDataValuewithObject(以對象取代數(shù)據(jù)值) 2008-04-02Chan
20、geValuetoReference(將實值對象改為引用對象) 2008-04-02ChangeReferencetoValue(將引用對象改為實值對象) 2008-04-02ReplaceArraywithObject(以對象取代數(shù)組) 2008-04-02DuplicateObservedData(復(fù)制被監(jiān)視數(shù)據(jù)) 2008-04-02ChangeUnidirectionalAssociationtoBidirectional(將單向關(guān)聯(lián)改為雙向) 2008-04-02ChangeBidirectionalAssociationtoUnidirectional(將雙向關(guān)聯(lián)改為單向) 200
21、8-04-02ReplaceMagicNumberwithSymbolicConstant(以符號常量/字面常量取代魔法數(shù)) 2008-04-02EncapsulateField(封裝值域) 2008-04-02EncapsulateCollection(封裝群集) 2008-04-02ReplaceRecordwithDataClass(以數(shù)據(jù)類取代記錄) 2008-04-02ReplaceTypeCodewithClass(以類取代型別碼) 2008-04-02ReplaceTypeCodewithSubclasses(以子類取代型別碼) 2008-04-02ReplaceTypeCode
22、withState/Strategy以State/Strategy取代型別碼) 2008-04-02ReplaceSubclasswithFields(以值域取代子類)2008-04-02 簡化條件表達(dá)式2008-04-02簡化條件表達(dá)式(1)DecomposeConditional(分解條件式)(2)ConsolidateConditionalExpression(合并條件式)(3)ConsolidateDuplicateConditionalFragments(合并重復(fù)的條件片段)(4)RemoveControlFlag(移除控制標(biāo)記)(5)ReplaceNestedConditional
23、withGuardClauses(以衛(wèi)語句取代嵌套條件式)(6)ReplaceConditionalwithPolymorphism(以多態(tài)取代條件式)(7)IntroduceNullObject(引入Null對象)(8)IntroduceAssertion(引入斷言) 2008-04-02DecomposeConditional(分解條件式) 2008-04-02ConsolidateConditionalExpression(合并條件式) 2008-04-02ConsolidateDuplicateConditionalFragments(合并重復(fù)的條件片段) 2008-04-02Remo
24、veControlFlag(移除控制標(biāo)記) 2008-04-02ReplaceNestedConditionalwithGuardClauses以衛(wèi)語句取代嵌套條件式) 2008-04-02ReplaceConditionalwithPolymorphism(以多態(tài)取代條件式) 2008-04-022008-04-02IntroduceNullObject(引入Null對象)2008-04-02IntroduceAssertion(引入斷言) 2008-04-02簡化函數(shù)調(diào)用(MakingMethodCallsSimpler) (1)RenameMethod(重新命名函數(shù))(2)AddPara
25、meter(添加參數(shù))(3)RemoveParameter(移除參數(shù))(4)SeparateQueryfromModifier(將查詢函數(shù)和修改函數(shù)分離)(5)ParameterizeMethod(令函數(shù)攜帶參數(shù))(6)ReplaceParameterwithExplicitMethods(以明確函數(shù)取代參數(shù))(7)PreserveWholeObject(保持對象完整) 2008-04-02(8)ReplaceParameterwithMethod(以函數(shù)取代參數(shù))(9)IntroduceParameterObject(引入?yún)?shù)對象)(10)RemoveSettingMethod(移除設(shè)值函數(shù)
26、)(11)HideMethod(隱藏你的函數(shù))(12)ReplaceConstructorwithFactoryMethod(以工廠方法取代構(gòu)造函數(shù))(13)EncapsulateDowncast(封裝向下轉(zhuǎn)型動作)(14)ReplaceErrorCodewithException(以異常取代錯誤碼)(15)ReplaceExceptionwithTest(以測試取代異常) 2008-04-02RenameMethod(重新命名函數(shù)) 2008-04-02AddParameter(添加參數(shù)) 2008-04-02RemoveParameter(移除參數(shù)) 2008-04-02SeparateQ
27、ueryfromModifier(將查詢函數(shù)和修改函數(shù)分離) 2008-04-02ParameterizeMethod(令函數(shù)攜帶參數(shù)) 2008-04-02ReplaceParameterwithExplicitMethods(以明確函數(shù)取代參數(shù)) 2008-04-02PreserveWholeObject(保持對象完整) 2008-04-02ReplaceParameterwithMethod(以函數(shù)取代參數(shù)) 2008-04-02IntroduceParameterObject(引入?yún)?shù)對象) 2008-04-02RemoveSettingMethod(移除設(shè)值函數(shù)) 2008-04-0
28、2HideMethod(隱藏你的函數(shù)) 2008-04-02ReplaceConstructorwithFactoryMethod(以工廠方法取代構(gòu)造函數(shù)) 2008-04-02EncapsulateDowncast(封裝向下轉(zhuǎn)型動作) 2008-04-02ReplaceErrorCodewithException(以異常取代錯誤碼) 2008-04-02ReplaceExceptionwithTest(以測試取代異常) 2008-04-02處理概括關(guān)系(DealingwithGeneralization) (1)PullUpField(值域上移)(2)PullUpMethod(函數(shù)上移)(3)PullUpConstructorBody(構(gòu)造函數(shù)本體上移)(4)PushDownMethod(函數(shù)下移)(5)PushDownField(值域下移)(6)ExtractSubclass(提煉子類) 2008-04-02(7)ExtractSuperclass(提煉超類)(8)ExtractInterface(提煉接口)(9)CollapseHierarchy(折疊繼承體系)(10)FormTemplateMethod(塑造模板函數(shù))(11)Replace
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 二年級數(shù)學(xué)下冊人教版 第二單元 第04課時 用2-6的乘法口訣求商(教學(xué)設(shè)計)
- 語文園地五 教學(xué)設(shè)計-2024-2025學(xué)年語文一年級上冊統(tǒng)編版
- 【核心素養(yǎng)目標(biāo)】4.13《辨方向》 教案
- 蘇教版六年級上冊勞動與技術(shù) 教學(xué)設(shè)計 做蛋糕
- 【高效備課】人教版八(上) 14.1 整式的乘法 14.1.4 整式的乘法 第2課時 多項式與多項式相乘 教案
- 粵教版八年級下冊第2單元 黃河兩岸的歌-《放風(fēng)箏》 教案
- 人教版 美術(shù)三年級上冊第6課 黑與白 教學(xué)設(shè)計
- DB6110-T 49-2024 釀酒葡萄種植技術(shù)規(guī)程
- 【素養(yǎng)目標(biāo)】人教版數(shù)學(xué)七年級下冊9.1.1 不等式及其解集 教案
- 素質(zhì)訓(xùn)練 教學(xué)設(shè)計-2023-2024學(xué)年高一上學(xué)期體育與健康人教版必修第一冊
- 五年級語文新課程標(biāo)準(zhǔn)
- 中等職業(yè)學(xué)校突發(fā)事件輿情處置應(yīng)急預(yù)案
- 小學(xué)演講比賽規(guī)則與評分標(biāo)準(zhǔn)
- 小升初英語復(fù)習(xí)題三十套(含詳細(xì)解析)
- 隱形領(lǐng)導(dǎo)力:不帶團(tuán)隊你也不用一個人干
- 表聚羧酸系高性能減水劑原始記錄
- 關(guān)于成立安全生產(chǎn)領(lǐng)導(dǎo)小組的通知
- 井岡山中國紅色精神專題培訓(xùn)課件
- 重慶網(wǎng)格員考試題庫2023
- 加強(qiáng)醫(yī)護(hù)人員的職業(yè)素養(yǎng)培養(yǎng)
- 大飛機(jī)C919:追夢五十載,“破繭化蝶”
評論
0/150
提交評論