無數(shù)次經(jīng)驗(yàn)里,我們看到某個(gè)函數(shù)為了計(jì)算某值,從另一個(gè)對象那兒調(diào)用幾乎半打的取值函數(shù)(getting method)。療法顯而易見:把這個(gè)函數(shù)移至另一個(gè)地點(diǎn)。你應(yīng)該使用Move Method(142)把它移到它該去的地方。有時(shí)侯函數(shù)中只有一部分受這種依戀之苦,這時(shí)候你應(yīng)該使用Extract Method(110)把這一部分提煉到獨(dú)立函數(shù)中,再使用Move Method(142)帶它去它的夢中家園。
當(dāng)然,并非所有情況都這么簡單。一個(gè)函數(shù)往往會(huì)用上數(shù)個(gè)classes特性,那么它究竟該被置于何處呢?我們的原則是:判斷哪個(gè)class擁有最多[被此函數(shù)使用]的數(shù)據(jù),然后就把這個(gè)函數(shù)和那些數(shù)據(jù)擺在一起。如果先以Extract Method(110)將這個(gè)函數(shù)分解為數(shù)個(gè)較小函數(shù)并分別置放于不同地點(diǎn),上述步驟也就比較容易完成了。
有數(shù)個(gè)復(fù)雜精巧的模式(patterns)破壞了這個(gè)規(guī)則。說起這個(gè)話題,[四巨頭][Gang of Four]的Strategy和Visitor立刻跳入我的腦海,Kent Beck的Self Delegation[Beck]也在此列。使用這些模式是為了對抗壞味道Divergent Change。最根本的原則是:將總是一起變化的東西放在一塊兒。[數(shù)據(jù)]和[引用這些數(shù)據(jù)]的行為總是一起變化的,但也有例外。如果例外出現(xiàn),我們就搬移那些行為,保持[變化只在一地發(fā)生]。Strategy和Visitor使你得以輕松修改函數(shù)行為,因?yàn)樗鼈儗⑸倭啃璞桓矊懀╫verridden)的行為隔離開來-當(dāng)然也付出了[多一層間接性]的代價(jià)。
當(dāng)然,并非所有情況都這么簡單。一個(gè)函數(shù)往往會(huì)用上數(shù)個(gè)classes特性,那么它究竟該被置于何處呢?我們的原則是:判斷哪個(gè)class擁有最多[被此函數(shù)使用]的數(shù)據(jù),然后就把這個(gè)函數(shù)和那些數(shù)據(jù)擺在一起。如果先以Extract Method(110)將這個(gè)函數(shù)分解為數(shù)個(gè)較小函數(shù)并分別置放于不同地點(diǎn),上述步驟也就比較容易完成了。
有數(shù)個(gè)復(fù)雜精巧的模式(patterns)破壞了這個(gè)規(guī)則。說起這個(gè)話題,[四巨頭][Gang of Four]的Strategy和Visitor立刻跳入我的腦海,Kent Beck的Self Delegation[Beck]也在此列。使用這些模式是為了對抗壞味道Divergent Change。最根本的原則是:將總是一起變化的東西放在一塊兒。[數(shù)據(jù)]和[引用這些數(shù)據(jù)]的行為總是一起變化的,但也有例外。如果例外出現(xiàn),我們就搬移那些行為,保持[變化只在一地發(fā)生]。Strategy和Visitor使你得以輕松修改函數(shù)行為,因?yàn)樗鼈儗⑸倭啃璞桓矊懀╫verridden)的行為隔離開來-當(dāng)然也付出了[多一層間接性]的代價(jià)。