最終的效果是:你應該更積極進取地分解函數(shù)。我們遵循這樣一條原則:每當感覺需要以注釋來說明點什么的時候,我們就把需要說明的東西寫進一個獨立函數(shù)中,
并以其用途(而非實現(xiàn)手法)命名。我們可以對一組或甚至短短一行代碼做這件事。哪怕替換后的函數(shù)調用動作比函數(shù)自身還長,只要函數(shù)名稱能夠解釋其用途,我
們也該毫不猶豫地那么做。關鍵不在于函數(shù)長度,而在于函數(shù)[做什么]和[如何做]之間的語義距離。
百分之九十九的場合里,要把函數(shù)變小,只需使用Extract Method(110)。找到函數(shù)中適合集在一起的部分,將它們提煉出來形成一個新函數(shù)。
如果函數(shù)內(nèi)有大量的參數(shù)和臨時變量,它們會對你的函數(shù)提煉形成阻礙。如果你嘗試運用Extract Method(110),最終就會把許多這些參數(shù)和臨時變量當作參數(shù),傳遞給被提煉出來的新函數(shù),導致可讀性幾乎沒有任何提升。啊是的,你可以經(jīng)常運用Replace Temp with Query(120)來消除這些暫時元素。Introduce Parameter Object(295)和Preserve Whole Object(288)則可以將過長的參數(shù)列變得更簡潔一些。
如果你已經(jīng)這么做了,仍然有太多臨時變量和參數(shù),那就應該使出我們的殺手锏:Replace Method with Method Object(135)。
如何確定該提煉哪一段代碼呢?一個很好的技巧是:尋找注解。它們通常是指出[代碼用途和實現(xiàn)手法間的語義距離]的信號。如果代碼前方有一行注解,就是在提
醒你:可以將這段代碼替換成一個函數(shù),而且可以在注解的基礎上給這個函數(shù)命名。就算只有一行代碼,如果它需要以注解來說明,那也值得將它提煉到獨立函數(shù)
去。
條件式和循環(huán)常常也是提煉的信號。你可以使用Decompose Conditional(238)處理條件式。至于循環(huán),你應該將循環(huán)和其內(nèi)的代碼提煉到一個獨立函數(shù)中。