重構(gòu)原則
重構(gòu)的幾個(gè)定義
重構(gòu)(名詞):對(duì)軟件內(nèi)部結(jié)構(gòu)的一種調(diào)整,目的是在不改變"軟件之可察行為"前提下,提高其可理解性,降低其修改成本。
重構(gòu)(動(dòng)詞):使用一系列重構(gòu)準(zhǔn)則(手法),在不改變"軟件之可察行為"的前提下,調(diào)整其結(jié)構(gòu)。
重構(gòu)和性能優(yōu)化的相同之處:通常都不會(huì)改變組件的行為,只會(huì)改變其內(nèi)部結(jié)構(gòu)。
重構(gòu)和性能優(yōu)化的不同之處:出發(fā)點(diǎn)不同。性能優(yōu)化往往使代碼較難理解,但為了得到所需的性能,你不得不那么做。
兩頂帽子
添加新功能和重構(gòu)是兩種截然不同的行為。添加新功能時(shí),你不應(yīng)該修改既有代碼,只管添加新功能。通過測(cè)試,你可以衡量你自己的工作進(jìn)度;重構(gòu)時(shí)你就不能再添加功能,只管改進(jìn)程序結(jié)構(gòu)。此時(shí)你不應(yīng)該添加任何測(cè)試(除非你發(fā)現(xiàn)先前遺漏的任何東西),只在絕對(duì)必要(用以處理接口變化)時(shí)才修改測(cè)試。
軟件開發(fā)過程當(dāng)中,你可能會(huì)經(jīng)常更換帽子,但是無論在什么時(shí)候,都必須清楚自己戴的是哪一頂帽子。
重構(gòu)的目的:
1、重構(gòu)改進(jìn)軟件設(shè)計(jì)
同樣完成一件事,設(shè)計(jì)不良的程序往往需要更多代碼,這常常是因?yàn)榇a在不同的地方使用完全相同的語句做同樣的事。因此改進(jìn)設(shè)計(jì)的一個(gè)重要方向就是消除重復(fù)代碼。如果消除重復(fù)代碼,你就可以確定代碼將所有事物和行為都只表述一次,唯一一次,這正是優(yōu)秀設(shè)計(jì)的根本。
2、重構(gòu)使程序更容易被理解
要及時(shí)填補(bǔ)想要他做什么和告訴他做什么之間的縫隙。這種編程模式的核心就是“準(zhǔn)確說出吾人所欲”。
這種可理解性還有另一方面的作用。我利用重構(gòu)來協(xié)助我理解不熟悉的代碼。當(dāng)我看到不熟悉的代碼,我必須試著理解其用途。我先看兩行代碼,然后對(duì)自己說:“噢,是的,它做了那些......”。有了重構(gòu)這個(gè)強(qiáng)大武器在手,我不會(huì)滿足于這么一點(diǎn)腦中體會(huì)。我會(huì)真正動(dòng)手修改代碼,讓他更好的反應(yīng)出我的理解,然后重新執(zhí)行,看它是否能夠仍然正常運(yùn)作,以此檢驗(yàn)我的理解是否正確。
3、重構(gòu)助你找到臭蟲
重構(gòu)能夠幫助我寫出強(qiáng)健穩(wěn)固的代碼。
4、重構(gòu)助你提高編程速度
良好設(shè)計(jì)是維持軟件開發(fā)速的的根本。重構(gòu)可以幫助你更快速的開發(fā)軟件,因?yàn)樗柚瓜到y(tǒng)腐敗變質(zhì),它甚至可以提高設(shè)計(jì)質(zhì)量。
重構(gòu)的時(shí)機(jī)
重構(gòu)本來就不是一件“特別撥出時(shí)間做”的事情,重構(gòu)應(yīng)該隨時(shí)隨地進(jìn)行。不應(yīng)該為重構(gòu)而重構(gòu),重構(gòu)是因?yàn)槟阆胱鰟e的事,重構(gòu)可以幫助你把事情做好。
事不過三,三則重構(gòu).
1、添加功能時(shí)一并重構(gòu)
想要理解代碼-->重構(gòu)-->理解代碼
想要添加特性-->重構(gòu)-->更容易的添加特性
2、修補(bǔ)錯(cuò)誤時(shí)一并重構(gòu)
如果在修改錯(cuò)誤的時(shí)候,不能一眼發(fā)現(xiàn)錯(cuò)誤,說明需要重構(gòu)。
3、復(fù)審代碼時(shí)一并重構(gòu)
復(fù)審代碼有助于在開發(fā)團(tuán)隊(duì)中傳播知識(shí)。
重構(gòu)可以幫助我復(fù)審別人的代碼。
得到一定程度的理解-->想到一些點(diǎn)子-->重構(gòu)-->進(jìn)一步的理解-->更好的點(diǎn)子。如果不進(jìn)行重構(gòu),我永遠(yuǎn)也無法得到這樣的認(rèn)識(shí)。
最好是一個(gè)復(fù)審者搭配一個(gè)原作者,共同處理這些代碼。復(fù)審者提出修改建議,然后兩人共同判斷這些修改能否通過重構(gòu)輕松實(shí)現(xiàn)。果真能夠如此,就一起著手修改。
為什么重構(gòu)有用(Why Refactoring Works)
---Kent Beck
程序具有兩面價(jià)值:今天可以為你做什么,明天可以為你做什么。大多數(shù)時(shí)候,我們都只關(guān)注自己今天想要程序做什么。不論是修復(fù)錯(cuò)誤或是添加特性,我們都是為了讓程序能力更強(qiáng),讓它在今天更有價(jià)值。
但是系統(tǒng)今天(當(dāng)下)的行為,只是整個(gè)故事的一部分,如果沒有認(rèn)清這一點(diǎn),你無法長(zhǎng)期從事編程工作。如果你“為求完成今天任務(wù)”而采取的手法使你不可能在明天完成明天的任務(wù),那么你還是失敗。但是,你知道自己今天需要什么,卻不一定知道自己明天需要什么。也許你可以猜到明天的需求,也許吧,但肯定還有些事情出乎你的意料。
對(duì)于今天的工作,了解得很充分;對(duì)于明天的工作,我了解得不夠充分。但如果我純粹只是為今天工作,明天我將完全無法工作。
重構(gòu)是一條擺脫束縛的道路。如果你發(fā)現(xiàn)昨天的決定已經(jīng)不適合今天的情況,放心改變這個(gè)決定就是,然后你就可以完成今天的工作了。明天,喔,明天回頭看今天的理解也許覺得很幼稚,那時(shí)你還可以改變你的理解。
是什么讓程序如此難以相與?下筆此刻,我想起四個(gè)原因,它們是:
難以閱讀的程序,難以修改;
邏輯重復(fù)的程序,難以修改;
添加新行為時(shí)需要修改既有代碼者,難以修改。
帶復(fù)雜邏輯條件的程序,難以修改。
因此我們希望程序:(1)容易閱讀;(2)所有邏輯都只在唯一地點(diǎn)指定;(3)新的改動(dòng)不會(huì)危及現(xiàn)有行為;(4)盡可能簡(jiǎn)單表達(dá)邏輯條件。
重構(gòu)是這樣一個(gè)過程:它在一個(gè)目前可以運(yùn)行的程序上進(jìn)行,企圖在“不改變程序行為”的情況下賦予上述美好性質(zhì),使我們能夠繼續(xù)保持高速開發(fā),從而增加程序的價(jià)值。
posted on 2007-06-21 22:37
littlegai 閱讀(183)
評(píng)論(0) 編輯 收藏 引用