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

企業(yè)與個(gè)人網(wǎng)絡(luò)營銷一站式服務(wù)商
網(wǎng)站建設(shè) / SEO優(yōu)化排名 / 小程序開發(fā) / OA
0731-88571521
136-3748-2004
什么是重構(gòu),什么不是重構(gòu)
信息來源:斌網(wǎng)網(wǎng)絡(luò)--行政組   發(fā)布時(shí)間:2012-5-14   瀏覽:

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

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

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

重構(gòu)的結(jié)果是引用了快捷方法、去除了重復(fù)代碼和死代碼,使設(shè)計(jì)和邏輯更加清晰。是在更好的、更聰明的使用編程語言。是在優(yōu)勢(shì)利用你現(xiàn)在知道、但當(dāng)時(shí)的開發(fā)程序員并不知道——或并沒有加以利用的信息。不斷的簡化代碼,讓它們更容易理解。不斷的使它們?cè)趯淼淖兏兊酶菀住⒏踩?/p>

在這個(gè)過程中發(fā)現(xiàn)了bug、修改bug,這不是重構(gòu)。優(yōu)化不是重構(gòu)。強(qiáng)化異常捕捉、增加預(yù)防性代碼不是重構(gòu)。讓代碼更容易測(cè)試不是重構(gòu)——盡管重構(gòu)能達(dá)到相同的效果。這些所有的事都是有益的。但這些都不是重構(gòu)。

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

重構(gòu)很簡單。盡可能在寫代碼前先寫測(cè)試能夠防止你犯錯(cuò)誤。小規(guī)模的、獨(dú)立的、穩(wěn)妥的對(duì)代碼進(jìn)行結(jié)構(gòu)上的調(diào)整,每次調(diào)整完后都要進(jìn)行測(cè)試,確保你沒有改變代碼的行為特征——功能和以前一樣,只是代碼上看著不同。重構(gòu)模式和現(xiàn)代化的IDE里的重構(gòu)工具使重構(gòu)變得容易、安全和代價(jià)低廉。

不要為了重構(gòu)而重構(gòu)

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

你不是為了重構(gòu)而重構(gòu),你重構(gòu)是因?yàn)槟阆胱銎渌氖虑椋貥?gòu)能幫助你完成這些事情。

重構(gòu)的范圍應(yīng)該受你需要實(shí)施的代碼變更或代碼修正來決定——為了讓代碼變更更安全和更簡潔,你應(yīng)該做些什么?換句話說:不要為了重構(gòu)而重構(gòu)。不要對(duì)那些你不打算進(jìn)行變更或不會(huì)變更的代碼進(jìn)行重構(gòu)。

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

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

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

什么是“大規(guī)模”重構(gòu)?

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

相對(duì)于這些較小的、行內(nèi)的重構(gòu),更加重大的設(shè)計(jì)上的重構(gòu)與之有明顯差異——這就是Martin Fowler所指的”大型重構(gòu)”。大的、代價(jià)很高的變動(dòng),附帶有大量的技術(shù)風(fēng)險(xiǎn)。這不是你編程過程中的清理代碼和設(shè)計(jì)改進(jìn):這是根本性的重新設(shè)計(jì)。

有些人喜歡把對(duì)一個(gè)系統(tǒng)的重新設(shè)計(jì)或重寫或重新搭建平臺(tái)或返工叫“大規(guī)模重構(gòu)”。因?yàn)榧夹g(shù)上講,這些并不改變軟件功能特征——業(yè)務(wù)邏輯、軟件輸入和輸出仍和以前一樣,“只是”設(shè)計(jì)和代碼實(shí)現(xiàn)變了。它和常規(guī)重構(gòu)的區(qū)別看起來就是:一個(gè)是重寫了一段代碼,一個(gè)是重寫了一個(gè)系統(tǒng),只要你是一步一步做下來的,你都可以稱之為“重構(gòu)”——不管你是長年累月被困于將一個(gè)老系統(tǒng)換成新代碼,還是對(duì)系統(tǒng)架構(gòu)進(jìn)行大規(guī)模的改造。

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

而且在開發(fā)新代碼的同時(shí)你還要維護(hù)舊代碼,這使得代碼版本控制很麻煩,變更起來不方便,致使代碼很脆弱,易犯錯(cuò)——這正和重構(gòu)所預(yù)期的目的背道而馳。有時(shí)這樣的情況會(huì)一直持續(xù)下去——這種新舊代碼交替的過程永遠(yuǎn)不能完成,因?yàn)槟塬@得最大利益的部分都是最先完成,或者因?yàn)樽畛鯉磉@個(gè)想法的顧問已經(jīng)干別的去了,或者是預(yù)算被消減,而且你也討厭維護(hù)這樣一個(gè)拖拉的項(xiàng)目。

這些是重構(gòu)——那些不是

在這種重型的項(xiàng)目開發(fā)過程中混入重構(gòu)的概念是不對(duì)的。它們從根本上就是另外一種工作,帶有完全不同的開發(fā)成本和風(fēng)險(xiǎn)。它混淆了人們對(duì)什么是重構(gòu)、重構(gòu)能干什么的認(rèn)識(shí)。

重構(gòu)可以、也應(yīng)該融入到你寫代碼或維護(hù)代碼的過程中——作為日常開發(fā)/質(zhì)量管理的組成部分,就像寫測(cè)試和代碼審查一樣。重構(gòu)應(yīng)該被安靜的,持續(xù)的和低調(diào)的完成。它需要我們把工作精力分出一部分給它,它需要在我們的工期評(píng)估和風(fēng)險(xiǎn)評(píng)估中考慮到它的存在。如果做的正確,你不需要去解釋或向外人驗(yàn)證這部分工作。

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

有些程序員認(rèn)為對(duì)代碼進(jìn)行根本的、重大的修改是他們的權(quán)利和義務(wù),在重構(gòu)的名義下進(jìn)行重新設(shè)計(jì)、重寫,為了將來,也不辜負(fù)自己的技藝。重新設(shè)計(jì)和重寫有時(shí)候是你正確的該做的事情。但出于坦誠和表述清楚,請(qǐng)不要把這些活動(dòng)賦以重構(gòu)的名義。




上一條: 做企業(yè)網(wǎng)站優(yōu)化方案
下一條: 大學(xué)生創(chuàng)業(yè)自辦網(wǎng)上商城 半年?duì)I收近20萬
案例鑒賞
多年的網(wǎng)站建設(shè)經(jīng)驗(yàn),斌網(wǎng)網(wǎng)絡(luò)不斷提升技術(shù)設(shè)計(jì)服務(wù)水平,迎合搜索引擎優(yōu)化規(guī)則
新聞中心
多年的網(wǎng)站建設(shè)經(jīng)驗(yàn),網(wǎng)至普不斷提升技術(shù)設(shè)計(jì)服務(wù)水平,迎合搜索引擎優(yōu)化規(guī)則
長沙私人做網(wǎng)站    長沙做網(wǎng)站    深圳網(wǎng)站建設(shè)    株洲做網(wǎng)站    東莞做網(wǎng)站    湖南大拇指養(yǎng)豬設(shè)備    株洲做網(wǎng)站    
版權(quán)所有 © 長沙市天心區(qū)斌網(wǎng)網(wǎng)絡(luò)技術(shù)服務(wù)部    湘公網(wǎng)安備 43010302000270號(hào)  統(tǒng)一社會(huì)信用代碼:92430103MA4LAMB24R  網(wǎng)站ICP備案號(hào):湘ICP備13006070號(hào)-2  
日韩欧美伦理_精品成人乱色一区二区_国产精品巨作av_欧美视频国产精品
西瓜成人精品人成网站| 欲色影视综合吧| 欧美激情一区二区三区全黄| 国产精品国产三级国产普通话99 | 99视频国产精品免费观看| 午夜精品视频在线观看| 欧美日韩精品二区| 最新日韩在线视频| 理论片一区二区在线| 国内一区二区三区| 久久高清福利视频| 国产一区日韩欧美| 久久精品视频99| 激情五月婷婷综合| 欧美1区3d| 亚洲精品少妇网址| 欧美日韩国产在线看| 亚洲精品综合| 欧美日韩亚洲一区二区三区在线| 一区二区三区四区国产精品| 国产精品久久久久久久午夜| 亚洲视屏在线播放| 国产精品免费福利| 欧美中文字幕视频| 国产伊人精品| 欧美大片一区二区三区| 亚洲国产精品国自产拍av秋霞| 免费成人黄色av| 亚洲激情欧美激情| 欧美日韩精品综合| 亚洲一区视频| 国产精品亚洲一区| 国产一区二区三区自拍| 亚洲综合电影| 亚洲欧美日韩专区| 亚洲欧洲日本国产| 欧美日在线观看| 国产免费观看久久| 亚洲国产一区二区三区在线播| 亚洲国产老妈| 老司机凹凸av亚洲导航| 欧美一级片一区| 国产精品色网| 欧美在线国产精品| 亚洲福利电影| 久久久久亚洲综合| 欧美日韩一区不卡| 国产精品影院在线观看| 狠狠色伊人亚洲综合成人| 91久久一区二区| 日韩一级免费| 久久精品国产精品亚洲精品| 欧美精品18| 国产一区二区三区日韩| 亚洲精品一区中文| 在线播放亚洲一区| 亚洲在线第一页| 欧美日韩国产精品专区| 国产日韩精品在线| 久久精品国产视频| 亚洲毛片在线观看.| 免费亚洲电影在线观看| 国产综合久久久久久| 亚洲欧美另类综合偷拍| 国产精品成人v| 久热精品在线视频| 免费欧美日韩国产三级电影| 欧美岛国激情| 国内自拍视频一区二区三区| 99视频一区二区三区| 欧美日韩精品一区二区三区| 欧美成人精精品一区二区频| 免费久久99精品国产自在现线| 日韩一区二区免费高清| 国产亚洲永久域名| 欧美日韩精品免费观看视一区二区| 欧美一区二区高清| 在线观看亚洲精品| 亚洲欧美视频在线观看| 欧美成人三级在线| 亚洲精品乱码久久久久久久久| 久久精品免费电影| 极品少妇一区二区| 欧美成人午夜激情在线| 国产精品福利影院| 欧美专区一区二区三区| 欧美视频一区二区三区| 亚洲性av在线| 亚洲精品乱码| 欧美亚洲视频| 一区二区欧美精品| 国产在线视频欧美一区二区三区| 欧美揉bbbbb揉bbbbb| 麻豆精品在线视频| 久久久综合精品| 久久激情中文| 小黄鸭精品aⅴ导航网站入口| 亚洲视频福利| 一区二区三区日韩欧美| 亚洲精品视频在线观看免费| 亚洲国产aⅴ天堂久久| 黑人巨大精品欧美一区二区小视频| 国产精品网站一区| 国产精品电影在线观看| 亚洲婷婷在线| 亚洲欧美国产另类| 亚洲欧美国产视频| 午夜欧美精品久久久久久久| 亚洲在线第一页| 亚洲欧美电影在线观看| 香蕉成人久久| 午夜精品久久久久久久99樱桃 | 亚洲午夜性刺激影院| 99国产精品视频免费观看一公开| 亚洲肉体裸体xxxx137| 亚洲人成绝费网站色www| 亚洲国产精品久久久久婷婷老年 | 国产色综合天天综合网| 国产精品亚洲综合一区在线观看 | 久久理论片午夜琪琪电影网| 一区二区久久久久| 亚洲激情在线观看视频免费| 国产精品久久久999| 亚洲国产高清视频| 亚洲国产精彩中文乱码av在线播放| 国产午夜精品久久久| 国产私拍一区| 精品粉嫩aⅴ一区二区三区四区| 在线播放视频一区| 欧美一级播放| 亚洲影院免费观看| 亚洲专区欧美专区| 午夜免费久久久久| 欧美黑人一区二区三区| 久久久久久亚洲精品不卡4k岛国| 亚洲欧美日韩精品久久久久| 亚洲欧美中日韩| 性欧美1819性猛交| 老牛国产精品一区的观看方式| 美女久久一区| 国产精品国产三级国产普通话三级 | 国内成+人亚洲| 1024精品一区二区三区| 亚洲乱码国产乱码精品精可以看 | 国产精品视频一二| 久久人人爽人人爽| 欧美精品色网| 国一区二区在线观看| 欧美日韩一区二区精品| 久久精品伊人| 在线视频一区观看| 欧美一级免费视频| 农村妇女精品| 欧美国产日韩精品免费观看| 国产精品乱人伦中文| 在线观看成人小视频| 一区二区三区四区蜜桃| 久久久欧美一区二区| 亚洲综合欧美| 亚洲精品欧美一区二区三区| 亚洲欧美国产高清| 欧美成人资源| 国产日韩欧美黄色| 亚洲精品一区二区三区四区高清 | 国产精品久久久久毛片软件 | 亚洲激情在线| 亚洲午夜电影在线观看| 免费观看在线综合色| 国产在线播精品第三| 欧美淫片网站| 国产日韩精品一区二区| 亚洲视频在线观看一区| 欧美日韩一区免费| 野花国产精品入口| 国产麻豆精品久久一二三| 亚洲一区二区在线免费观看视频| 国内久久精品| 小黄鸭精品aⅴ导航网站入口| 国产欧美精品在线播放| 欧美亚洲一级片| 欧美精品导航| 亚洲一区二区三区视频| 国精品一区二区三区| 欧美一级片在线播放| 欧美日韩理论| 久久综合免费视频影院| 欧美一区高清| 欧美性久久久| 午夜精品久久久| 一本色道久久综合亚洲精品按摩| 一区二区视频欧美| 欧美另类videos死尸| 国产嫩草一区二区三区在线观看| 国产日韩欧美在线视频观看| 亚洲精品在线电影| 久久精品国产精品亚洲综合| 国产精品蜜臀在线观看| 在线亚洲一区| 美女日韩在线中文字幕| 国产视频精品va久久久久久|