ivaneeo's blog

          自由的力量,自由的生活。

            BlogJava :: 首頁 :: 聯(lián)系 :: 聚合  :: 管理
            669 Posts :: 0 Stories :: 64 Comments :: 0 Trackbacks
          無數(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]的StrategyVisitor立刻跳入我的腦海,Kent Beck的Self Delegation[Beck]也在此列。使用這些模式是為了對抗壞味道Divergent Change。最根本的原則是:將總是一起變化的東西放在一塊兒。[數(shù)據(jù)]和[引用這些數(shù)據(jù)]的行為總是一起變化的,但也有例外。如果例外出現(xiàn),我們就搬移那些行為,保持[變化只在一地發(fā)生]。StrategyVisitor使你得以輕松修改函數(shù)行為,因?yàn)樗鼈儗⑸倭啃璞桓矊懀╫verridden)的行為隔離開來-當(dāng)然也付出了[多一層間接性]的代價(jià)。
          posted on 2005-08-18 17:09 ivaneeo 閱讀(2287) 評論(0)  編輯  收藏 所屬分類: refactoring-從地獄中重生
          主站蜘蛛池模板: 荥阳市| 长宁区| 西吉县| 调兵山市| 黄骅市| 湖南省| 大洼县| 双桥区| 伊吾县| 赣州市| 建水县| 怀仁县| 上虞市| 砀山县| 漳平市| 平顶山市| 工布江达县| 南通市| 册亨县| 南投县| 阿尔山市| 启东市| 新晃| 博湖县| 汝城县| 仙桃市| 安福县| 阜康市| 嘉鱼县| 当涂县| 罗甸县| 阿城市| 新河县| 瑞金市| 瑞丽市| 昭苏县| 农安县| 浙江省| 平原县| 哈巴河县| 北辰区|