亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

關于refactoring思考

2019-11-18 13:19:18
字體:
來源:轉載
供稿:網友

  雖然refactoring幾乎可以隨時進行,然而,按照我們關于兩頂帽子的原則,在某些場合下 ,refactoring的介入顯得更加實際、有意義、富有成效。
  
  另外,在最后進入Refactoring實踐之前,我把Kent Beck和Martin Fowler給我們的忠告和建議放在這里。這些內容,非凡是Code Smell和命名規則不但對我們進行refactoring具有很強的實踐意義。同時,他們也促使我們對很多OO設計和編碼的原則進行更多的思考。
  Refactoring 應用的場合
  
  增加功能
  假如你的代碼不需要增加新的功能,那么你幾乎沒有必要對他進行Refactoring。增加功能是進行Refactoring最常見的起因。通常,refactoring的第一個目標就是為了讓代碼更輕易理解。Refactoring不僅僅可以使難以理解的代碼更加清楚,他也可以使你對它的理解呈現一種交互狀態,你和代碼的交互。理解了,新的功能就很輕易加入。
  
  另一個原因是原來代碼的結構很難直接擴展,可能是因為一個類和另外一個類的綁定太緊,或者是他使用了大量的case語句,或者是有一些重復的代碼讓你覺得加入你的代碼會使結構更差??偠灾苯蛹尤胄鹿δ懿皇翘奖?。這時候,你就需要Refactoring,使得舊的代碼在能讓舊的test case通過的情況下,讓新的代碼加入更加方便、快捷。
  
  重用
  重用可以說是增加功能的一個特例。因為這是OO增加功能最主要的方法。但這里有一些差別。
  
  假如你的代碼是一個框架,那么當把代碼交給其他人使用時,你必須重點考慮框架的重用方法。譬如,你想在框架之上增加一層facade,這時候,你可能需要refactoring一些內部類,讓這個Facade的結構更輕易加入。
  
  對框架Refactoring可能需要是一個反饋的過程。因為框架一旦穩定就可能長期存在,一般你不會直接對這個框架增加功能。這時,不同應用程序對框架使用經驗的積累可能使得你的Refactoring具有更加明確的目標,更加深層次的抽象。
  
  修正bug
  bug產生的原因有很多??赡苁悄銓鉀Q的問題理解不夠,也可能是程序的代碼過于紛亂。當你的代碼結構不是很清楚時,bug往往隱藏在代碼之中,使你很難發現。應用Refactoring讓代碼結構結構更清楚的同時,也使得bug自動浮出水面。
  
  Refactoring所追求的目標和過程往往使得代碼的Bug無處遁形。Eric E. Allen在IBM中developerWorks的bug pattern中的一個模式就是copy-and-paste方法造成代碼重復,從而產生bug的一個例子。這個 Rogue Title Pattern是一個非經常見的bug例子,當你修正了程序中一個bug時,你發現程序運行的結果是你明明已經修正的bug還在作怪。究其原因,就是程序員在實現一個功能的時候把一段代碼復制過去,稍加修改,就成為一個新的函數。你修改了一個地方,但卻忘了另外一個地方。
  
  Refactoring力求排除重復代碼,假如有這樣的bug,在refactoring以后,一次修改就能糾正所有的問題。
  
  Code Review
  Review可以使得專家知識傳播到整個開發隊伍。他們能夠幫助更多的人理解一個大系統更多方面的問題。它們對于編寫清楚的代碼也有很好的幫助。俗話說得好,三個臭皮匠頂一個諸葛亮,Review也使得你能夠接受更多其他人的好意見和想法,從而使你的設計和代碼更加合理。
  
  按照Martin Fowler的建議,我使用refactoring作為我的主要review方法。我有比較多的機會做這樣的Code Review,在程序員發現一個難以解決的bug,或者當他們覺得自己的思路無法進行下去的時候,他們通常會要求我的幫助。
  
  我的方法通常是問幾個簡單的問題,然后直接找到他們的代碼,進行refactoring,在這個過程中,我總是一邊refactoring,一邊和程序員講解我這樣做的意圖。令人驚異的是,一旦我這樣去做,程序員往往能夠在我refactoring的過程中自己發現問題。由于Refactoring的結果非常具體,我很輕易對程序員講述一些本來就可以直接這樣實現的例子,這對提高程序員的編程能力有極大的幫助。
  
  味道
  Kent Beck的" Code Smell"或許是OO社團最有人情味的名言了。Martin Fowler和Kent Beck專門合著了《Refactoring》其中的一章就叫《Bad Smells in Code》。
  
  雖然對Refactoring的研究涉及到了形式化地探測代碼的結構,譬如專門的重復代碼監測工具。但這些研究尚處于幼年期。更何況,很多代碼的結構并不是能夠用簡單的數字統計和抽象語法樹所能解決的。
  
  Code Smell是高水平的程序員對代碼的一種感覺,當你能夠聞到這樣的味道時,你就可以在不涉及到程序所要解決的具體問題時,就"聞到"代碼結構的好壞。
  
  Kent Beck 和Martin Fowler列出的代碼味道有:
  
  Duplicated Code
  代碼重復幾乎是最常見的異味了。他也是Refactoring的主要目標之一。代碼重復往往來自于copy-and-paste的編程風格。與他相對應OAOO是一個好系統的重要標志(請參見我的duplicated code一文)。
  
  Long method
  它是傳統結構化的"遺毒"。一個方法應當具有自我獨立的意圖,不要把幾個意圖放在一起,我的《大類和長方法》一文中有具體描述。
  
  Large Class
  大類就是你把太多的責任交給了一個類。這里的規則是One Class One Responsibility。參見我的《大類和長方法》。
  
  Divergent Change
  一個類里面的內容變化率不同。某些狀態一個小時變一次,某些則幾個月一年才變一次;某些狀態因為這方面的原因發生變化,而另一些則因為其他方面的原因變一次。面向對象的抽象就是把相對不變的和相對變化相隔離。把問題變化的一方面和另一方面相隔離。這使得這些相對不變的可以重用。問題變化的每個方面都可以單獨重用。這種相異變化的共存使得重用非常困難。
  
  Shotgun Surgery
  這正好和上面相反。對系統一個地方的改變涉及到其他許多地方的相關改變。這些變化率和變化內容相似的狀態和行為通常應當放在同一個類中。
  
  Feature Envy
  對象的目的就是封裝狀態以及與這些狀態緊密相關的行為。假如一個類的方法頻繁用get方法存取其他類的狀態進行計算,那么你要考慮把行為移到涉及狀態數目最多的那個類。
  
  Data Clumps
  某些數據通常像孩子一樣成群玩耍:一起出現在很多類的成員變量中,一起出現在許多方法的參數中… ,這些數據或許應該自己獨立形成對象。
  
  PRimitive Obsession
  面向對象的新手通常習慣使用幾個原始類型的數據來表示一個概念。譬如對于范圍,他們會使用兩個數字。對于Money,他們會用一個浮點數來表示。因為你沒有使用對象來表達問題中存在的概念,這使得代碼變的難以理解,解決問題的難度大大增加。好的習慣是擴充語言所能提供原始類型,用小對象來表示范圍、金額、轉化率、郵政編碼等等。
  
  Switch Statement
  基于常量的開關語句是OO的大敵,你應當把他變為子類、state或
  trategy。
  Parallel Inheritance Hierarchies
  并行的繼續層次是shotgun surgery的非凡情況。因為當你改變一個層次中的某一個類時,你必須同時改變另外一個層次的并行子類。
  
  Lazy Class
  一個干活不多的類。類的維護需要額外的開銷,假如一個類承擔了太少的責任,應當消除它。
  
  Speculative Generality
  一個類實現了從未用到的功能和通用性。通常這樣的類或方法唯一的用戶是test case。不要猶豫,刪除它。
  
  Temporary Field
  一個對象的屬性可能只在某些情況下才有意義。這樣的代碼將難以理解。專門建立一個對象來持有這樣的孤兒屬性,把只和他相關的行為移到該類。最常見的是一個特定的算法需要某些只有該算法才有用的變量。
  
  Message Chain
  消息鏈發生于當一個客戶向一個對象要求另一個對象,然后客戶又向這另一對象要求另一個對象,再向這另一個對象要求另一個對象,如此如此。這時,你需要隱藏分派。
  
  Middle Man
  對象的基本特性之一就是封裝,而你經常會通過分派去實現封裝。但是這一步不能走得太遠,假如你發現一個類接口的一大半方法都在做分派,你可能需要移去這個中間人。
  
  Inappropriate Intimacy
  某些類相互之間太親密,它們花費了太多的時間去磚研別人的私有部分。對人類而言,我們也許不應該太假正經,但我們應當讓自己的類嚴格遵守禁欲主義。
  
  Alternative Classes with Different Interfaces
  做相同事情的方法有不同的函數signature,一致把它們往類層次上移,直至協議一致。
  
  Incomplete Library Class
  要建立一個好的類庫非常困難。我們大量的程序工作都基于類庫實現。然而,如此廣泛而又相異的目標對庫構建者提出了苛刻的要求。庫構建者也不是萬能的。有時候我們會發現庫類無法實現我們需要的功能。而直接對庫類的修改有非常困難。這時候就需要用各種手段進行Refactoring。
  
  Data Class
  對象包括狀態和行為。假如一個類只有狀態沒有行為,那么肯定有什么地方出問題了。
  
  Refused Bequest
  超類傳下來很多行為和狀態,而子類只是用了其中的很小一部分。這通常意味著你的類層次有問題。
  
  Comments
  經常覺得要寫很多注釋表示你的代碼難以理解。假如這種感覺太多,表示你需要Refactoring。
  
  Refactoring和命名
  Refactoring使代碼更輕易理解的最有效和常用的手段之一就是給類、方法和屬性一個恰如其分的名字。很多公司和個人都編出了大量的代碼命名規范。假如這些規范太繁瑣,那就無法執行。有好的命名規則是好事,但并不總是如此。最重要的是,在整個

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产综合福利在线| 97在线精品国自产拍中文| 日韩欧美一区视频| 中文字幕精品久久久久| 欧美精品成人91久久久久久久| 亚洲精品美女久久久久| 日韩av电影免费观看高清| 国内外成人免费激情在线视频| 欧美理论电影在线观看| 国产91色在线播放| 日韩欧美高清视频| 国产美女久久精品| 一本久久综合亚洲鲁鲁| 国产欧美日韩高清| 日韩成人av在线播放| 一区二区在线免费视频| 国产精品亚洲精品| 色播久久人人爽人人爽人人片视av| 亚洲电影av在线| 日韩精品视频免费专区在线播放| 欧美一区二区视频97| 亚洲第一精品夜夜躁人人躁| 精品女同一区二区三区在线播放| 青青草原成人在线视频| 精品久久久久久久久久国产| 久久久av免费| 91久久精品国产91久久性色| 中文字幕欧美日韩va免费视频| 色综合视频网站| 久久夜色撩人精品| 亚洲第一精品电影| 国产男女猛烈无遮挡91| 国产精品久久一区主播| 精品日韩美女的视频高清| 国产成人综合精品在线| 亚洲精品久久在线| 一个人www欧美| 亚洲伊人久久大香线蕉av| 日韩欧美在线观看视频| 亚洲无限av看| 欧美中文字幕在线| 在线中文字幕日韩| 成人欧美一区二区三区在线| 久久精品国产欧美激情| 中文字幕一区二区三区电影| 亚洲大胆人体视频| 欧美最顶级丰满的aⅴ艳星| 社区色欧美激情 | 国产成人精品久久| 91av网站在线播放| 亚洲第一精品夜夜躁人人躁| 亚洲自拍偷拍色片视频| 亚洲国产另类 国产精品国产免费| 欧美高清视频一区二区| 日韩精品欧美国产精品忘忧草| 美女福利精品视频| 国产精品99久久久久久久久久久久| 中文字幕综合在线| 国产日韩精品在线| 91国语精品自产拍在线观看性色| 国产精品美乳一区二区免费| 狠狠躁夜夜躁人人爽天天天天97| 欧美性生交大片免网| 精品亚洲一区二区三区在线观看| 欧美国产日韩一区二区在线观看| 日韩av电影院| 国产激情综合五月久久| 最新69国产成人精品视频免费| 国产日产欧美a一级在线| 国产精品麻豆va在线播放| 亚洲欧美精品在线| 一本一道久久a久久精品逆3p| 精品爽片免费看久久| 久久99国产精品自在自在app| 亚洲区中文字幕| 欧美在线观看网址综合| 国产精品www网站| 亚洲国产女人aaa毛片在线| 日韩视频免费中文字幕| 精品色蜜蜜精品视频在线观看| 91久久精品美女高潮| 欧美成人精品不卡视频在线观看| 国产精品无av码在线观看| 久久久久久久久91| 久久久最新网址| 欧美黄色三级网站| 亚洲国产天堂久久综合网| 亚洲国产婷婷香蕉久久久久久| 97国产精品久久| 亚洲自拍偷拍第一页| 亚洲电影免费在线观看| 亚洲香蕉成人av网站在线观看| 亚洲国产精品视频在线观看| 69视频在线播放| 亚洲欧美成人网| 国产午夜精品免费一区二区三区| 欧美日韩精品在线视频| 国产欧美一区二区三区在线看| 亚洲欧美综合区自拍另类| 97色在线视频观看| 亚洲最大激情中文字幕| 日本高清不卡在线| 国产精品a久久久久久| 日韩av在线免费观看一区| 欧美电影免费观看| 5278欧美一区二区三区| 日韩视频免费大全中文字幕| 亚洲国产精品久久久久| 青青久久av北条麻妃黑人| 欧美成年人网站| 日韩精品在线观看网站| 久久高清视频免费| 色av吧综合网| 国产精品网红直播| 亚洲一区二区三区香蕉| 久久综合伊人77777蜜臀| 欧美视频专区一二在线观看| 成人国产精品色哟哟| 成人黄色中文字幕| 国产一区二区三区高清在线观看| 国产精品99久久99久久久二8| 午夜精品久久久久久久99热浪潮| 欧美大片在线免费观看| 日韩一区二区三区国产| 黄色成人在线免费| 日韩精品视频在线免费观看| 一区二区三区视频观看| 国产亚洲美女久久| 久久久精品久久| 亚洲第一精品电影| 日韩欧美大尺度| 日韩在线视频免费观看高清中文| 蜜月aⅴ免费一区二区三区| 中文字幕日韩综合av| 欧美日韩精品在线播放| 亚洲美女性生活视频| 在线观看亚洲视频| 日韩午夜在线视频| 国产精品爽黄69天堂a| 亚洲成人网在线观看| 欧美日韩国产第一页| 亚洲欧美资源在线| 国产精品欧美在线| 成人网在线视频| 亚洲а∨天堂久久精品喷水| 欧美激情视频免费观看| 久久亚洲成人精品| 欧美精品在线视频观看| 欧美高清视频在线观看| 高清一区二区三区四区五区| 亚洲精品美女视频| 性色av香蕉一区二区| 日韩中文字幕免费视频| 亚洲欧洲自拍偷拍| 欧美激情免费视频| 亚洲国产成人爱av在线播放| 最近2019年中文视频免费在线观看| 在线看国产精品| 亚洲男人天堂网| 亚洲精品国精品久久99热一| 色综合色综合久久综合频道88| 亚洲成色999久久网站| 日韩经典中文字幕| 国产精品揄拍一区二区|