?
什么是重構(gòu)?
“重構(gòu)”一詞想必你已經(jīng)聽膩了,就是整理代碼唄,不不不,重構(gòu)旨在不改變調(diào)用者行為的前提下,對(duì)內(nèi)部邏輯進(jìn)行調(diào)整優(yōu)化,提高其理解性,降低其修改成本,它是一門藝術(shù),是程序員至高無上的榮耀……
?
何時(shí)重構(gòu)?怎么重構(gòu)?
經(jīng)常聽到周邊的人抱怨沒有時(shí)間重構(gòu),重構(gòu)并不是單獨(dú)抽出時(shí)間集中處理的,而是當(dāng)你想要做某個(gè)功能時(shí),隨手把需要重構(gòu)的地方安排了。
?
邏輯重復(fù)
重復(fù)代碼是最核心常見的預(yù)警信息,如果有兩個(gè)及以上的重復(fù)邏輯,就應(yīng)該考慮將其合并。比如同一類或不同類中的函數(shù)存在相同邏輯的部分,就應(yīng)該把相同部分抽象為獨(dú)立函數(shù)或類。
?
長函數(shù)
應(yīng)該有很多同學(xué)經(jīng)手過別人數(shù)百行甚至上千行的代碼,讓人質(zhì)疑人生。為方便理解,最好的方式是把長函數(shù)分解為若干小函數(shù),搭配上易理解的函數(shù)名,便可以像自然語言一樣理解代碼。
?
參數(shù)過多
有一種習(xí)慣非常不好,就是把所有要用到的變量當(dāng)做函數(shù)的參數(shù),這樣會(huì)加劇代碼的理解難度,拓展極其困難,當(dāng)需要更多數(shù)據(jù)時(shí),不得不修改所有函數(shù)的參數(shù),牽一發(fā)動(dòng)全身。如果把對(duì)象作為參數(shù),需要用到的數(shù)據(jù)都放進(jìn)對(duì)象里,就可以有效解決參數(shù)過長的問題。
?
函數(shù)出軌
你要是發(fā)現(xiàn)一個(gè)函數(shù)頻繁的調(diào)用某一個(gè)類,它很可能給你戴了綠帽子,不如忍痛割愛,放其自由吧,把函數(shù)歸并到它喜歡的類,也許他們?cè)谝黄鹕罡鼮楹线m,你一定會(huì)找到一個(gè)適合的人。
?
變化擴(kuò)散
如果新加入一個(gè)業(yè)務(wù)類型(例如支付渠道、數(shù)據(jù)庫類型等)時(shí),需要改動(dòng)很多地方才能實(shí)現(xiàn),這就意味著還有改進(jìn)的空間,可以將引起變化的原因抽出來做為配置,并將變化的函數(shù)放置到一個(gè)類中,這樣不僅可以做到修改一處就應(yīng)對(duì)變化,還可以很清晰的知道哪些函數(shù)會(huì)受到影響。
?
工具小助手
一款語言包含很多基本類型與內(nèi)置函數(shù),但不能滿足所有需求,比如金額單位轉(zhuǎn)換、時(shí)間數(shù)組格式轉(zhuǎn)換、UUID生成等簡單又容易忽略的小功能,如果這些功能出現(xiàn)的頻率很高,規(guī)則改變會(huì)帶來一連串的修改,這時(shí)可以考慮將這些小功能抽象為工具函數(shù),并將這些函數(shù)組合為工具類。
?
意淫的功能
有些邏輯以為將來會(huì)有一些變化,于是安插了很多鉤子函數(shù)應(yīng)對(duì)非必要的特殊情況,這樣往往提高了系統(tǒng)復(fù)雜性和理解成本,如果安插的鉤子都能被用到且有價(jià)值,那么就使用,否則還是不要放在代碼里阻礙視線了。
?
switch過多
假如現(xiàn)在要做一個(gè)支持微信、支付寶、招行等渠道的支付平臺(tái),需要對(duì)接不同渠道,因?yàn)椴煌缹?duì)接方式不同,就需要用switch來根據(jù)類型選擇對(duì)應(yīng)渠道的對(duì)接方式,但是很多地方都可能用到這個(gè)switch,一旦新渠道加入就要滿世界的找哪里用到了switch。
可以將switch語句移植為獨(dú)立的函數(shù),將這些函數(shù)組成基類,case語句調(diào)用子類對(duì)應(yīng)的函數(shù),具體實(shí)現(xiàn)讓子類去完成,這樣支付渠道的增加和變更只需要修改一個(gè)類即可。
?
多余的類
創(chuàng)建的每一個(gè)類,對(duì)于其他人來講都是有理解成本的,如果曾經(jīng)為某個(gè)變化所添加的類,在實(shí)際場景中并沒有發(fā)生變化,那么就把這個(gè)類去掉吧,我們需要真正有價(jià)值、理解成本低的系統(tǒng)。
讓人犯暈的變量
一個(gè)類會(huì)設(shè)置一些為特殊情況設(shè)置的變量,這些變量不一定都會(huì)被使用,經(jīng)手你代碼的人還要猜測當(dāng)時(shí)設(shè)置這些變量的目的,非常讓人頭大,不如把這些變量和相關(guān)函數(shù)單獨(dú)放在一個(gè)類中,屏蔽具體細(xì)節(jié),需要的功能通過函數(shù)來表達(dá),會(huì)使功能擴(kuò)展更高效。
?
幽靈類
項(xiàng)目中偶爾會(huì)出現(xiàn)一些“幽靈類”,這些類沒有做什么實(shí)際工作,只是負(fù)責(zé)調(diào)用其它的類,不如把這個(gè)“中間人”去掉,讓實(shí)際要調(diào)用的那個(gè)類與調(diào)用者發(fā)生關(guān)系。
?
雷同的類
如果兩個(gè)類,其中某幾個(gè)函數(shù)作用相同,名稱不同,那就可以通過修改名稱或移植函數(shù)的方式將兩個(gè)相似的類保持一致,然后把兩個(gè)類抽象出基類,以便擴(kuò)展。
?
過多的注釋
注釋多并不是一件壞事,它是重構(gòu)的領(lǐng)路人,當(dāng)你感覺需要為某段代碼寫上注釋時(shí),這意味著你認(rèn)為這段代碼不容易被他人理解,也側(cè)面證明了這就是重構(gòu)發(fā)出的預(yù)警信號(hào),所以當(dāng)想要寫注釋時(shí),就先重構(gòu),爭取讓注釋都變得多余。
?
?
來源:http://www.icode9.com/content-4-202901.html聯(lián)系客服