在書寫代碼時,有一些不好的習(xí)慣,形象點說,可以說成代碼的“壞味道”,以下是一些常見的代碼的壞味道:
1. Duplicated Code(重復(fù)的代碼)
常見情況:
1) 同一個類中class內(nèi)的兩個函數(shù)含有相同表達(dá)式;
2) 兩個互為兄弟的子類內(nèi)含有相同表達(dá)式;
3) 兩個毫不相關(guān)的類中出現(xiàn)重復(fù)的代碼。
對于第1種情況,使用Extract Method重構(gòu)規(guī)則提煉重復(fù)代碼,讓這兩個地點都調(diào)用提煉出的那段代碼。
對于第2種情況,首先使用Extract Method重構(gòu)規(guī)則提煉重復(fù)代碼,接著將提煉出來的代碼使用Pull Up Method這條重構(gòu)規(guī)則將其提取到超類中。
對于第3種情況,常常使用Extract Class重構(gòu)規(guī)則將代碼提取到一個獨立的類中。
2. Long Method(過長的函數(shù))
99%的場合,要把函數(shù)變小,只需使用Extract Method重構(gòu)規(guī)則。找到函數(shù)中適合集在一起的部分,將它們提煉出來形成一個新函數(shù)。
3. Large Class(過大類)
可以使用Extract Class和Extract Subclass兩條重構(gòu)規(guī)則將一個過大的類變成多個小的類。
4. Long Parameter List(過長參數(shù)列)
如果“向既有對象發(fā)出一個請求”就可以取得原本位于參數(shù)列上的一份數(shù)據(jù),那么可以通過Replace Parameter with Method重構(gòu)規(guī)則來解決這個問題。還可以使用Rreserve Whole Object重構(gòu)規(guī)則將來自同一對象的一堆數(shù)據(jù)手機(jī)起來,并以該對象替換它們。如果某些對象缺乏合理的對象歸屬,可使用Introduce Parameter Object重構(gòu)規(guī)則為它們制造出一個“參數(shù)對象”。
5. Middle Man(中間轉(zhuǎn)手人)
人們可能過度運(yùn)用delegation。你也許會看到某個類接口有一半的函數(shù)都委托給其他class,這樣就是過度運(yùn)用,可以使用Remove Middle Man這條重構(gòu)規(guī)則之間和實責(zé)對象打交道。如果轉(zhuǎn)手人還有其他行為,可以運(yùn)用Replace Delegation with Inheritance這條重構(gòu)規(guī)則,將它變成實責(zé)對象的子類,這樣你既可以擴(kuò)展原對象的行為,又不必負(fù)擔(dān)那么多的委托工作。
6. Incomplete Library Class(不完美的程序庫類)
如果只想修改library classes內(nèi)的一兩個函數(shù),可以使用Introduce Foreign Method重構(gòu)規(guī)則;如果想要添加一大堆額外行為,就得使用Introduce Local Extension重構(gòu)規(guī)則。
7. Refused Bequest(被拒絕的饋贈)
子類應(yīng)該繼承超類的函數(shù)和數(shù)據(jù),如果它們不想或不需要繼承,這就意味著繼承體系設(shè)計有誤,此時可以使用Replace Inheritance with Delegation重構(gòu)規(guī)則。
8. Comments(過多的注釋)
如果你需要注釋來解釋一段代碼做了什么,試試使用Extract Method重構(gòu)規(guī)則;如果方法已經(jīng)被提取出來,但還是需要注釋來解釋其行為,試試Rename Method重構(gòu)規(guī)則;如果你需要注釋說明某些系統(tǒng)的需求規(guī)則,試試Intrduct Assertion重構(gòu)規(guī)則。
參考:
《重構(gòu)——改善既有代碼的設(shè)計》
posted on 2008-06-22 13:56
阿蜜果 閱讀(2386)
評論(1) 編輯 收藏 所屬分類:
Java