<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    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

      大類就是你把太多的責(zé)任交給了一個(gè)類。這里的規(guī)則是One Class One Responsibility.

      4.Divergent Change

      一個(gè)類里面的內(nèi)容變化率不同。某些狀態(tài)一個(gè)小時(shí)變一次,某些則幾個(gè)月一年才變一次;某些狀態(tài)因?yàn)檫@方面的原因發(fā)生變化,而另一些則因?yàn)槠渌矫娴脑蜃円淮巍C嫦驅(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è)類中。

      6.Feature Envy

      對(duì)象的目的就是封裝狀態(tài)以及與這些狀態(tài)緊密相關(guān)的行為。如果一個(gè)類的方法頻繁用get 方法存取其他類的狀態(tài)進(jìn)行計(jì)算,那么你要考慮把行為移到涉及狀態(tài)數(shù)目最多的那個(gè)類。

      7.Data Clumps

      某些數(shù)據(jù)通常像孩子一樣成群玩耍:一起出現(xiàn)在很多類的成員變量中,一起出現(xiàn)在許多方法的參數(shù)中,這些數(shù)據(jù)或許應(yīng)該自己獨(dú)立形成對(duì)象。

      8.Primitive Obsession

      面向?qū)ο蟮男率滞ǔA?xí)慣使用幾個(gè)原始類型的數(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ǔ)言所能提供原始類型,用小對(duì)象來(lái)表示范圍、金額、轉(zhuǎn)化率、郵政編碼等等。

      9.Switch Statement

      基于常量的開(kāi)關(guān)語(yǔ)句是OO 的大敵,你應(yīng)當(dāng)把他變?yōu)樽宇悺tate或strategy.

      10. Parallel Inheritance Hierarchies

      并行的繼承層次是shotgun surgery的特殊情況。因?yàn)楫?dāng)你改變一個(gè)層次中的某一個(gè)類時(shí),你必須同時(shí)改變另外一個(gè)層次的并行子類。

      11. Lazy Class

      一個(gè)干活不多的類。類的維護(hù)需要額外的開(kāi)銷,如果一個(gè)類承擔(dān)了太少的責(zé)任,應(yīng)當(dāng)消除它。

      12. Speculative Generality

      一個(gè)類實(shí)現(xiàn)了從未用到的功能和通用性。通常這樣的類或方法唯一的用戶是testcase.不要猶豫,刪除它。

      13. Temporary Field

      一個(gè)對(duì)象的屬性可能只在某些情況下才有意義。這樣的代碼將難以理解。專門建立一個(gè)對(duì)象來(lái)持有這樣的孤兒屬性,把只和他相關(guān)的行為移到該類。最常見(jiàn)的是一個(gè)特定的算法需要某些只有該算法才有用的變量。

      14. Message Chain

      消息鏈發(fā)生于當(dāng)一個(gè)客戶向一個(gè)對(duì)象要求另一個(gè)對(duì)象,然后客戶又向這另一對(duì)象要求另一個(gè)對(duì)象,再向這另一個(gè)對(duì)象要求另一個(gè)對(duì)象,如此如此。這時(shí),你需要隱藏分派。

      15. Middle Man

      對(duì)象的基本特性之一就是封裝,而你經(jīng)常會(huì)通過(guò)分派去實(shí)現(xiàn)封裝。但是這一步不能走得太遠(yuǎn),如果你發(fā)現(xiàn)一個(gè)類接口的一大半方法都在做分派,你可能需要移去這個(gè)中間人。

      16. Inappropriate Intimacy

      某些類相互之間太親密,它們花費(fèi)了太多的時(shí)間去磚研別人的私有部分。對(duì)人類而言,我們也許不應(yīng)該太假正經(jīng),但我們應(yīng)當(dāng)讓自己的類嚴(yán)格遵守禁欲主義。

      17. Alternative Classes with Different Interfaces

      做相同事情的方法有不同的函數(shù)signature,一致把它們往類層次上移,直至協(xié)議一致。

      18. Incomplete Library Class

      要建立一個(gè)好的類庫(kù)非常困難。我們大量的程序工作都基于類庫(kù)實(shí)現(xiàn)。然而,如此廣泛而又相異的目標(biāo)對(duì)庫(kù)構(gòu)建者提出了苛刻的要求。庫(kù)構(gòu)建者也不是萬(wàn)能的。有時(shí)候我們會(huì)發(fā)現(xiàn)庫(kù)類無(wú)法實(shí)現(xiàn)我們需要的功能。而直接對(duì)庫(kù)類的修改有非常困難。這時(shí)候就需要用各種手段進(jìn)行Refactoring.

      19. Data Class

      對(duì)象包括狀態(tài)和行為。如果一個(gè)類只有狀態(tài)沒(méi)有行為,那么肯定有什么地方出問(wèn)題了。

      20. Refused Bequest

      超類傳下來(lái)很多行為和狀態(tài),而子類只是用了其中的很小一部分。這通常意味著你的類層次有問(wèn)題。

      21. Comments

      經(jīng)常覺(jué)得要寫很多注釋表示你的代碼難以理解。如果這種感覺(jué)太多,表示你需要Refactoring。

    posts - 9, comments - 6, trackbacks - 0, articles - 1

    Copyright © 丁丁

    主站蜘蛛池模板: 久久久久一级精品亚洲国产成人综合AV区 | 日本高清免费中文在线看| 国产亚洲女在线线精品| 免费国产在线精品一区| 三级毛片在线免费观看| 一级特黄aa毛片免费观看| 91香蕉国产线在线观看免费| 和日本免费不卡在线v| 日韩一区二区三区免费体验| 区三区激情福利综合中文字幕在线一区亚洲视频1 | 亚洲精品国产日韩无码AV永久免费网 | 亚洲制服中文字幕第一区| 亚洲另类古典武侠| 久久精品国产亚洲AV未满十八| 又大又硬又粗又黄的视频免费看| 精品四虎免费观看国产高清午夜| 1000部拍拍拍18免费网站| 麻豆国产入口在线观看免费| 国产亚洲精品AA片在线观看不加载 | 亚洲视频手机在线| 亚洲av午夜国产精品无码中文字| 免费播放国产性色生活片| 久草免费福利视频| 成人a免费α片在线视频网站| 亚洲一区无码精品色| 亚洲午夜成激人情在线影院| 免费观看又污又黄在线观看| 日日麻批免费40分钟无码| 日韩毛片无码永久免费看| 亚洲阿v天堂在线| 亚洲综合一区无码精品| 韩国免费a级作爱片无码| 亚洲三级高清免费| 一本色道久久综合亚洲精品高清| 亚洲人成日本在线观看| xxxx日本在线播放免费不卡| 欧亚精品一区三区免费| 亚洲一区爱区精品无码| 亚洲免费福利在线视频| 免费看成人AA片无码视频吃奶| 最近2019中文字幕免费看最新|