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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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




上一條: 做企業(yè)網(wǎng)站優(yōu)化方案
下一條: 大學生創(chuàng)業(yè)自辦網(wǎng)上商城 半年營收近20萬
案例鑒賞
多年的網(wǎng)站建設(shè)經(jīng)驗,斌網(wǎng)網(wǎng)絡(luò)不斷提升技術(shù)設(shè)計服務水平,迎合搜索引擎優(yōu)化規(guī)則
新聞中心
多年的網(wǎng)站建設(shè)經(jīng)驗,網(wǎng)至普不斷提升技術(shù)設(shè)計服務水平,迎合搜索引擎優(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ǎng)安備 43010302000270號  統(tǒng)一社會信用代碼:92430103MA4LAMB24R  網(wǎng)站ICP備案號:湘ICP備13006070號-2  
日韩欧美伦理_精品成人乱色一区二区_国产精品巨作av_欧美视频国产精品
欧美国产精品久久| 久久丝袜美腿综合| 久久午夜电影网| 一区二区三区中文字幕电影| 久久er99热精品一区二区| 91免费观看视频在线| 欧美成人激情免费网| 亚洲狠狠丁香婷婷综合久久久| 麻豆国产精品一区二区三区| 日本道色综合久久| 久久综合九色综合久久久精品综合| 亚洲乱码国产乱码精品精可以看| 国内精品伊人久久久久av一坑| 色综合久久中文字幕| 国产日韩精品一区二区三区 | 国产成人综合网| 欧美一级在线观看| 亚洲不卡在线观看| 91在线小视频| 久久精品一二三| 国产在线国偷精品免费看| 欧美一区二区观看视频| 一区二区三区鲁丝不卡| 成人毛片老司机大片| 精品久久久久久久久久久久久久久久久 | 粉嫩av一区二区三区粉嫩| 欧美一区二区二区| 日韩专区中文字幕一区二区| 欧美性一级生活| 玉米视频成人免费看| 91免费版pro下载短视频| 国产精品高清亚洲| 国产iv一区二区三区| 国产欧美日韩中文久久| 国产乱子伦视频一区二区三区| 精品国产一区a| 国产一区二区三区综合 | 欧美在线不卡视频| 一区二区三区四区亚洲| 99精品久久免费看蜜臀剧情介绍| 亚洲欧美一区二区在线观看| 99vv1com这只有精品| 亚洲女人的天堂| 欧美在线制服丝袜| 亚洲成人黄色影院| 91精品国产色综合久久不卡蜜臀| 日韩精品一级二级 | 欧美人狂配大交3d怪物一区| 视频在线观看一区二区三区| 欧美一区二区三区在线看| 午夜久久电影网| 欧美成人精精品一区二区频| 国产成人av自拍| 18欧美亚洲精品| 欧美图片一区二区三区| 日韩成人免费电影| 久久精品人人爽人人爽| www.一区二区| 亚洲第一精品在线| 日韩亚洲欧美成人一区| 国产在线播放一区三区四| 中文字幕av在线一区二区三区| 一本色道久久综合亚洲91| 免费观看一级特黄欧美大片| 国产视频在线观看一区二区三区 | 国产精品麻豆视频| 欧美无砖砖区免费| 激情久久五月天| 亚洲精品日韩一| 欧美va亚洲va香蕉在线| 懂色一区二区三区免费观看| 国产精品久久久久影院亚瑟| 成人av在线一区二区三区| 夜夜操天天操亚洲| 欧美成人一区二区三区在线观看| 成人午夜伦理影院| 日日夜夜精品视频免费| 国产日产亚洲精品系列| 欧美精品乱码久久久久久| 国产精品88av| 日韩av一区二区三区四区| 国产日韩欧美精品在线| 在线综合亚洲欧美在线视频| 成人激情av网| 久久综合综合久久综合| 亚洲最大色网站| 国产精品国产三级国产aⅴ中文| 91精品国产综合久久久久久久久久| www.欧美日韩| 国产麻豆精品95视频| 午夜激情久久久| 亚洲男人天堂av| 久久久精品中文字幕麻豆发布| 欧美三区在线视频| 色综合婷婷久久| 成人午夜在线视频| 国产一区高清在线| 午夜视频在线观看一区| 1区2区3区精品视频| 久久久亚洲午夜电影| 欧美一区二区日韩一区二区| 91丨porny丨国产入口| 国产在线精品国自产拍免费| 青青草视频一区| 天堂va蜜桃一区二区三区| 亚洲色图制服诱惑 | 日韩中文字幕不卡| 亚洲日穴在线视频| 国产精品青草综合久久久久99| 日韩片之四级片| 91精品国产综合久久香蕉麻豆 | 成人免费在线视频| 久久久精品人体av艺术| 精品999在线播放| 精品国产乱码久久久久久夜甘婷婷 | 精品毛片乱码1区2区3区| 欧美日韩极品在线观看一区| 欧美午夜不卡视频| 欧亚一区二区三区| 欧美自拍偷拍午夜视频| 欧美日韩三级一区| 欧美性猛交xxxxxx富婆| 欧美群妇大交群中文字幕| 91在线观看一区二区| 成人理论电影网| 99久久国产综合精品女不卡| 色婷婷综合久久久| 欧美无砖砖区免费| 3751色影院一区二区三区| 日韩一级成人av| 国产视频一区二区在线| 中文字幕欧美日本乱码一线二线| 亚洲国产成人私人影院tom| 国产精品毛片大码女人| 亚洲六月丁香色婷婷综合久久| 一区二区欧美视频| 天天影视网天天综合色在线播放| 另类的小说在线视频另类成人小视频在线| 视频一区中文字幕国产| 韩国成人在线视频| 懂色一区二区三区免费观看| 91极品美女在线| 欧美一区二区成人| 久久精品视频网| 一区二区三区在线观看国产| 久久精品国产77777蜜臀| 国产成人综合亚洲91猫咪| 一本大道av伊人久久综合| 日韩一级黄色片| 亚洲视频免费观看| 蜜桃视频在线观看一区| eeuss鲁片一区二区三区在线观看| 在线观看视频一区| 欧美不卡一区二区| 亚洲乱码国产乱码精品精98午夜| 免费人成黄页网站在线一区二区| 国产91精品免费| 欧美二区三区91| 国产精品国产三级国产aⅴ中文| 青椒成人免费视频| www.亚洲精品| 精品国产凹凸成av人网站| 亚洲女爱视频在线| 国产精品正在播放| 欧美精品xxxxbbbb| 亚洲欧美综合色| 精品无码三级在线观看视频| 欧美视频一区二| 中文字幕中文字幕中文字幕亚洲无线| 日韩国产高清影视| 成人黄色一级视频| 日韩西西人体444www| 国产精品久久久久三级| 久久网站最新地址| 天堂在线亚洲视频| 成人免费毛片app| 色av一区二区| 精品国产污网站| 一区二区三区成人| 国产真实乱子伦精品视频| 欧美午夜一区二区三区免费大片| 久久先锋资源网| 亚洲成a人片在线不卡一二三区 | 欧美激情综合在线| 天天操天天干天天综合网| 高清不卡一二三区| 91超碰这里只有精品国产| 亚洲综合色视频| 成人精品视频一区二区三区| 日韩午夜电影在线观看| 亚洲动漫第一页| av不卡在线观看| 精品剧情v国产在线观看在线| 国产精品久久网站| 国产成人在线免费| 日韩欧美国产系列| 五月婷婷欧美视频| 51午夜精品国产| 亚洲一卡二卡三卡四卡五卡| 97久久精品人人做人人爽|