日韩欧美伦理_精品成人乱色一区二区_国产精品巨作av_欧美视频国产精品

企業與個人網絡營銷一站式服務商
網站建設 / SEO優化排名 / 小程序開發 / OA
0731-88571521
136-3748-2004
什么是重構,什么不是重構
信息來源:斌網網絡--行政組   發布時間:2012-5-14   瀏覽:

有時候,會有程序員跑到我這里說他們不喜歡某個東西的設計,“我們需要給它來個全面的重構”,來糾正里面的錯誤。哦,哦。這聽起來可不是個好主意。而且這聽起來也不是重構…

重構(Refactoring)這個詞最初由Martin Fowler 和 Kent Beck給下的定義,它是

一種修改,使軟件的內部結構更容易理解,在不改變軟件的可見行為方式前提下使軟件更容易變更…它是一種有節制的整理代碼、使bug產生幾率最小化的方法。

重構的結果是引用了快捷方法、去除了重復代碼和死代碼,使設計和邏輯更加清晰。是在更好的、更聰明的使用編程語言。是在優勢利用你現在知道、但當時的開發程序員并不知道——或并沒有加以利用的信息。不斷的簡化代碼,讓它們更容易理解。不斷的使它們在將來的變更變得更容易、更安全。

在這個過程中發現了bug、修改bug,這不是重構。優化不是重構。強化異常捕捉、增加預防性代碼不是重構。讓代碼更容易測試不是重構——盡管重構能達到相同的效果。這些所有的事都是有益的。但這些都不是重構。

程序員,特別是做維護工作的程序員,清理代碼是他們的日常工作之一。這是基本工作,是必須要做的。Martin Fowler等人的貢獻是使重構代碼的最佳實踐方法格式化,并把常見的、證明切實有效的重構模式——重構的目標和重構的步驟——進行歸檔分類。

重構很簡單。盡可能在寫代碼前先寫測試能夠防止你犯錯誤。小規模的、獨立的、穩妥的對代碼進行結構上的調整,每次調整完后都要進行測試,確保你沒有改變代碼的行為特征——功能和以前一樣,只是代碼上看著不同。重構模式和現代化的IDE里的重構工具使重構變得容易、安全和代價低廉。

不要為了重構而重構

重構可以被當成一種能給你的代碼變更帶來幫助的措施。代碼重構應該在你進行代碼變更前進行,這樣能讓你確信你對代碼理解了,使你更容易、更安全的把變更引入代碼。對你的重構動作進行回歸測試。然后進行糾正或變更。再次測試。之后可能需要對更多的代碼進行重構,使你代碼變更的意圖變得更加清晰。再次進行全面測試。重構,再變更。或變更,然后重構。

你不是為了重構而重構,你重構是因為你想做其它的事情,而重構能幫助你完成這些事情。

重構的范圍應該受你需要實施的代碼變更或代碼修正來決定——為了讓代碼變更更安全和更簡潔,你應該做些什么?換句話說:不要為了重構而重構。不要對那些你不打算進行變更或不會變更的代碼進行重構。

為理解而做簡略重構(Scratch Refactoring)

Michael Feather的《Working Effectively with Legacy Code》這本書里提到了簡略重構(Scratch Refactoring)的概念;Martin Fowler稱之為“為理解而重構”。這是用來對付那些你不理解的(或不能忍受的)代碼,清理它們,這樣在你打算真正動手修改它前,你能對它們是干什么的有了更好的理解,同樣也對你debug這些代碼有幫助。一旦你能清楚了一個變量或方法的真正意圖,重命名它們,給它們一個更合適的名稱,刪除那些你不喜歡看的(或覺得沒有用的)代碼,拆解復雜的條件語句,把長程序分解成數個容易理解的小程序。

不要惦記著復查或測試這些改動。這是為了讓你的重構快速的推進——這能讓這些代碼以及它們的運行原理在你的大腦里產生一個快速但不完備的原型。從中學習,然后丟掉它們。簡略重構還能讓你嘗試各種不同的重構途徑,學到更多的重構技巧。Michael Feathers建議說,在這個過程中要留意那些看起來沒什么用處、或者特別有用的東西,這樣當你完成此練習后、要真正修改它們時,才能把事情做正確——修改時一點一點來,講究方法,邊修改邊測試。

什么是“大規模”重構?

對代碼進行簡單的但又明顯的重構:消除重復,修改變量和方法名稱使其更有意義,提煉方法使代碼更易懂、更易復用,簡化條件邏輯,把無意義的數字換成命名的變量,把相似的代碼集中到一起。通過這些重構,在代碼的可理解性和可維護性上,你能得到巨大的回報。

相對于這些較小的、行內的重構,更加重大的設計上的重構與之有明顯差異——這就是Martin Fowler所指的”大型重構”。大的、代價很高的變動,附帶有大量的技術風險。這不是你編程過程中的清理代碼和設計改進:這是根本性的重新設計。

有些人喜歡把對一個系統的重新設計或重寫或重新搭建平臺或返工叫“大規模重構”。因為技術上講,這些并不改變軟件功能特征——業務邏輯、軟件輸入和輸出仍和以前一樣,“只是”設計和代碼實現變了。它和常規重構的區別看起來就是:一個是重寫了一段代碼,一個是重寫了一個系統,只要你是一步一步做下來的,你都可以稱之為“重構”——不管你是長年累月被困于將一個老系統換成新代碼,還是對系統架構進行大規模的改造。

“大規模重構”會變的很糟糕。你可能需要花數周、數月(甚至數年)才能完成,需要你對軟件的很多部分進行改動。軟件會因此不能運行,需要分多次發布這些變更,需要你做臨時的臺架(scaffolding)和變通方案——尤其是你采用短周期的敏捷開發方法時。這時Branch by Abstraction這樣的實踐方法就派上用場了,它能幫你在長周期內管理代碼中的變化。

而且在開發新代碼的同時你還要維護舊代碼,這使得代碼版本控制很麻煩,變更起來不方便,致使代碼很脆弱,易犯錯——這正和重構所預期的目的背道而馳。有時這樣的情況會一直持續下去——這種新舊代碼交替的過程永遠不能完成,因為能獲得最大利益的部分都是最先完成,或者因為最初帶來這個想法的顧問已經干別的去了,或者是預算被消減,而且你也討厭維護這樣一個拖拉的項目。

這些是重構——那些不是

在這種重型的項目開發過程中混入重構的概念是不對的。它們從根本上就是另外一種工作,帶有完全不同的開發成本和風險。它混淆了人們對什么是重構、重構能干什么的認識。

重構可以、也應該融入到你寫代碼或維護代碼的過程中——作為日常開發/質量管理的組成部分,就像寫測試和代碼審查一樣。重構應該被安靜的,持續的和低調的完成。它需要我們把工作精力分出一部分給它,它需要在我們的工期評估和風險評估中考慮到它的存在。如果做的正確,你不需要去解釋或向外人驗證這部分工作。

花幾分鐘、一兩個小時做重構,就像是你開發過程中的一種修改,是工作的一部分。如果它讓你花了數天時間,或者更長,那不是重構;那是重寫,或重新設計。如果你需要明確的留出一部分時間(或整個sprint周期)來重構代碼,如果需要為清理代碼而申請批準,或把清理代碼作為一個開發需求,那你不是在重構——即使你用了重構的技術和工具,你仍然做的是另外一種工作。

有些程序員認為對代碼進行根本的、重大的修改是他們的權利和義務,在重構的名義下進行重新設計、重寫,為了將來,也不辜負自己的技藝。重新設計和重寫有時候是你正確的該做的事情。但出于坦誠和表述清楚,請不要把這些活動賦以重構的名義。




上一條: 做企業網站優化方案
下一條: 大學生創業自辦網上商城 半年營收近20萬
案例鑒賞
多年的網站建設經驗,斌網網絡不斷提升技術設計服務水平,迎合搜索引擎優化規則
新聞中心
多年的網站建設經驗,網至普不斷提升技術設計服務水平,迎合搜索引擎優化規則
長沙私人做網站    長沙做網站    深圳網站建設    株洲做網站    東莞做網站    湖南大拇指養豬設備    株洲做網站    
版權所有 © 長沙市天心區斌網網絡技術服務部    湘公網安備 43010302000270號  統一社會信用代碼:92430103MA4LAMB24R  網站ICP備案號:湘ICP備13006070號-2  
日韩欧美伦理_精品成人乱色一区二区_国产精品巨作av_欧美视频国产精品
eeuss鲁一区二区三区| 欧美日韩精品一区二区三区| 成人h动漫精品一区二区| 欧美国产在线观看| 国产经典欧美精品| 欧美国产日韩一二三区| yourporn久久国产精品| 亚洲图片欧美一区| 91精品在线一区二区| 一区二区三区在线观看欧美| 欧美精品高清视频| 九九精品一区二区| 亚洲少妇30p| 91久久一区二区| 亚洲国产精品久久人人爱| 欧美一区午夜精品| 国产成人在线色| 亚洲丰满少妇videoshd| 欧美性淫爽ww久久久久无| 久久成人羞羞网站| 国产精品日韩精品欧美在线| 4438x成人网最大色成网站| 国产揄拍国内精品对白| 国产精品全国免费观看高清| 欧美性色黄大片手机版| 国产麻豆精品在线观看| 久久一区二区三区四区| 成人一级片网址| 天堂在线亚洲视频| 国产精品美女久久福利网站| 欧美精品一级二级三级| 久久精品国产亚洲高清剧情介绍| 日本一区二区三级电影在线观看| 91蝌蚪porny| 国产一二精品视频| 亚洲精品菠萝久久久久久久| 久久综合久久综合九色| 欧美日韩精品是欧美日韩精品| 国产经典欧美精品| 日本美女一区二区三区视频| 亚洲高清在线精品| 欧美国产精品v| 日韩欧美成人一区二区| 欧美欧美午夜aⅴ在线观看| 色综合久久久久网| 国产成人精品三级| 韩国av一区二区三区| 日韩国产一二三区| 亚洲一区二区三区小说| 国产精品成人网| 欧美激情艳妇裸体舞| 久久精品欧美一区二区三区麻豆| 日韩欧美电影一二三| 欧美一区二区日韩| 日韩欧美中文字幕制服| 欧美一区二区三区喷汁尤物| 韩日精品视频一区| 国产米奇在线777精品观看| 久久精品99久久久| 激情国产一区二区| 国产精品99久久久久久有的能看 | 国产精品久久网站| 亚洲国产精华液网站w| 中文字幕高清不卡| 亚洲欧美激情在线| 亚洲电影视频在线| 亚洲午夜视频在线| 日韩专区一卡二卡| 韩国av一区二区三区在线观看| 九九精品一区二区| 成人激情校园春色| 欧美在线观看视频一区二区 | 一本到一区二区三区| 99免费精品在线| 欧美日韩国产天堂| 欧美老年两性高潮| 久久久亚洲国产美女国产盗摄| 中文无字幕一区二区三区 | 91影院在线观看| 在线播放/欧美激情| 久久久亚洲精品石原莉奈| 欧美肥胖老妇做爰| 欧美一区二区三区性视频| 精品国产乱码久久| 337p粉嫩大胆色噜噜噜噜亚洲| 91视频在线看| 狠狠色丁香婷综合久久| 舔着乳尖日韩一区| 狠狠色丁香久久婷婷综合丁香| 久久99九九99精品| 亚洲视频电影在线| 欧美亚洲一区二区三区四区| 樱花草国产18久久久久| 国产精品12区| 成人高清免费在线播放| 国产精品免费久久| 欧美福利视频一区| 日韩精品一区二区三区中文不卡| 国产成人精品免费| 91成人在线免费观看| 久久夜色精品国产欧美乱极品| 一区二区三区国产精品| 国产一区二区网址| 日韩一区二区三| 亚洲综合视频网| 成人禁用看黄a在线| 欧美一区二区三区日韩视频| 亚洲一区在线观看网站| 成人午夜看片网址| 久久日一线二线三线suv| 天天色 色综合| 欧美午夜免费电影| 亚洲欧美一区二区视频| 国产成人一区二区精品非洲| 日韩视频在线永久播放| 午夜av区久久| 欧美日韩三级视频| 亚洲国产欧美日韩另类综合| 99久久精品久久久久久清纯| 久久久99久久| 国产一区二区三区免费播放| 日韩久久免费av| 美女网站在线免费欧美精品| 欧美一二三四在线| 麻豆国产精品官网| 欧美成人性福生活免费看| 日本人妖一区二区| 欧美一二区视频| 精品一区二区在线看| 26uuu色噜噜精品一区二区| 久久99久久久久| 久久精品日产第一区二区三区高清版 | 久久男人中文字幕资源站| 麻豆91精品91久久久的内涵| 欧美一二三在线| 国模套图日韩精品一区二区| 久久九九久久九九| a美女胸又www黄视频久久| 1区2区3区精品视频| 色菇凉天天综合网| 亚洲乱码中文字幕| 欧美精品丝袜中出| 日本中文字幕一区二区有限公司| 欧美视频在线一区二区三区| 一区二区三区在线观看动漫 | 国产精品嫩草影院com| 国产一区二区三区在线观看免费视频| 日韩美一区二区三区| 成人性生交大片免费看中文| 国产无一区二区| 欧美在线制服丝袜| 日韩中文字幕91| 精品人在线二区三区| 美女脱光内衣内裤视频久久影院| 欧美成人精品高清在线播放 | 精油按摩中文字幕久久| 精品国产自在久精品国产| 国产91在线|亚洲| 一区二区三区高清不卡| 欧美精品v国产精品v日韩精品| 国产精品一区在线观看你懂的| 国产日本欧洲亚洲| 色欧美片视频在线观看在线视频| 一区二区三区日韩精品视频| 日韩欧美一区二区在线视频| 国内偷窥港台综合视频在线播放| 亚洲欧美日韩在线播放| 欧美美女bb生活片| 韩国欧美国产1区| 亚洲综合激情小说| 日韩欧美国产精品| 精品视频一区二区不卡| 国产老女人精品毛片久久| 亚洲一区二区三区四区在线免费观看| 欧美日本精品一区二区三区| 国产成人精品亚洲午夜麻豆| 亚洲综合在线视频| 中文字幕二三区不卡| 欧美裸体一区二区三区| 福利视频网站一区二区三区| 亚洲午夜精品一区二区三区他趣| 日韩女优视频免费观看| 欧美日韩在线综合| 国产精品123区| 精品一区二区三区久久| 亚洲精品成人精品456| 国产亚洲精品超碰| 日韩午夜在线播放| 在线视频国产一区| 丁香婷婷综合色啪| 国产一区二区视频在线| 日韩高清在线电影| 亚洲综合成人在线视频| 国产精品动漫网站| 欧美第一区第二区| 欧美人妖巨大在线| 欧美裸体一区二区三区| 97成人超碰视| 在线观看免费亚洲| 色偷偷久久一区二区三区|