1.Duplicated Code
代碼重復(fù)幾乎是最常見(jiàn)的異味了。他也是Refactoring的主要目標(biāo)之一。代碼重復(fù)往往來(lái)自于copy-and-paste的編程風(fēng)格。與他相對(duì)應(yīng)OAOO是一個(gè)好系統(tǒng)的重要標(biāo)志。
2.Long method
它是傳統(tǒng)結(jié)構(gòu)化的“遺毒”。一個(gè)方法應(yīng)當(dāng)具有自我獨(dú)立的意圖,不要把幾個(gè)意圖放在一起。
3.Large Class
大類(lèi)就是你把太多的責(zé)任交給了一個(gè)類(lèi)。這里的規(guī)則是One Class One Responsibility.
4.Divergent Change
一個(gè)類(lèi)里面的內(nèi)容變化率不同。某些狀態(tài)一個(gè)小時(shí)變一次,某些則幾個(gè)月一年才變一次;某些狀態(tài)因?yàn)檫@方面的原因發(fā)生變化,而另一些則因?yàn)槠渌矫娴脑蜃円淮。面向(qū)ο蟮某橄缶褪前严鄬?duì)不變的和相對(duì)變化相隔離。把問(wèn)題變化的一方面和另一方面相隔離。這使得這些相對(duì)不變的可以重用。問(wèn)題變化的每個(gè)方面都可以單獨(dú)重用。這種相異變化的共存使得重用非常困難。
5.Shotgun Surgery
這正好和上面相反。對(duì)系統(tǒng)一個(gè)地方的改變涉及到其他許多地方的相關(guān)改變。這些變化率和變化內(nèi)容相似的狀態(tài)和行為通常應(yīng)當(dāng)放在同一個(gè)類(lèi)中。
6.Feature Envy
對(duì)象的目的就是封裝狀態(tài)以及與這些狀態(tài)緊密相關(guān)的行為。如果一個(gè)類(lèi)的方法頻繁用get 方法存取其他類(lèi)的狀態(tài)進(jìn)行計(jì)算,那么你要考慮把行為移到涉及狀態(tài)數(shù)目最多的那個(gè)類(lèi)。
7.Data Clumps
某些數(shù)據(jù)通常像孩子一樣成群玩耍:一起出現(xiàn)在很多類(lèi)的成員變量中,一起出現(xiàn)在許多方法的參數(shù)中,這些數(shù)據(jù)或許應(yīng)該自己獨(dú)立形成對(duì)象。
8.Primitive Obsession
面向?qū)ο蟮男率滞ǔA?xí)慣使用幾個(gè)原始類(lèi)型的數(shù)據(jù)來(lái)表示一個(gè)概念。譬如對(duì)于范圍,他們會(huì)使用兩個(gè)數(shù)字。對(duì)于Money,他們會(huì)用一個(gè)浮點(diǎn)數(shù)來(lái)表示。因?yàn)槟銢](méi)有使用對(duì)象來(lái)表達(dá)問(wèn)題中存在的概念,這使得代碼變的難以理解,解決問(wèn)題的難度大大增加。好的習(xí)慣是擴(kuò)充語(yǔ)言所能提供原始類(lèi)型,用小對(duì)象來(lái)表示范圍、金額、轉(zhuǎn)化率、郵政編碼等等。
9.Switch Statement
基于常量的開(kāi)關(guān)語(yǔ)句是OO 的大敵,你應(yīng)當(dāng)把他變?yōu)樽宇?lèi)、state或strategy.
10. Parallel Inheritance Hierarchies
并行的繼承層次是shotgun surgery的特殊情況。因?yàn)楫?dāng)你改變一個(gè)層次中的某一個(gè)類(lèi)時(shí),你必須同時(shí)改變另外一個(gè)層次的并行子類(lèi)。
11. Lazy Class
一個(gè)干活不多的類(lèi)。類(lèi)的維護(hù)需要額外的開(kāi)銷(xiāo),如果一個(gè)類(lèi)承擔(dān)了太少的責(zé)任,應(yīng)當(dāng)消除它。
12. Speculative Generality
一個(gè)類(lèi)實(shí)現(xiàn)了從未用到的功能和通用性。通常這樣的類(lèi)或方法唯一的用戶是testcase.不要猶豫,刪除它。
13. Temporary Field
一個(gè)對(duì)象的屬性可能只在某些情況下才有意義。這樣的代碼將難以理解。專(zhuān)門(mén)建立一個(gè)對(duì)象來(lái)持有這樣的孤兒屬性,把只和他相關(guān)的行為移到該類(lèi)。最常見(jiàn)的是一個(gè)特定的算法需要某些只有該算法才有用的變量。
希望與更多計(jì)算機(jī)等級(jí)考試的網(wǎng)友交流,請(qǐng)進(jìn)入計(jì)算機(jī)等級(jí)考試論壇
更多信息請(qǐng)?jiān)L問(wèn):考試吧計(jì)算機(jī)等級(jí)考試欄目
北京 | 天津 | 上海 | 江蘇 | 山東 |
安徽 | 浙江 | 江西 | 福建 | 深圳 |
廣東 | 河北 | 湖南 | 廣西 | 河南 |
海南 | 湖北 | 四川 | 重慶 | 云南 |
貴州 | 西藏 | 新疆 | 陜西 | 山西 |
寧夏 | 甘肅 | 青海 | 遼寧 | 吉林 |
黑龍江 | 內(nèi)蒙古 |