ivaneeo's blog

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

            BlogJava :: 首頁 :: 聯(lián)系 :: 聚合  :: 管理
            669 Posts :: 0 Stories :: 64 Comments :: 0 Trackbacks
          無數(shù)次經(jīng)驗里,我們看到某個函數(shù)為了計算某值,從另一個對象那兒調(diào)用幾乎半打的取值函數(shù)(getting method)。療法顯而易見:把這個函數(shù)移至另一個地點。你應(yīng)該使用Move Method(142)把它移到它該去的地方。有時侯函數(shù)中只有一部分受這種依戀之苦,這時候你應(yīng)該使用Extract Method(110)把這一部分提煉到獨立函數(shù)中,再使用Move Method(142)帶它去它的夢中家園。

          當(dāng)然,并非所有情況都這么簡單。一個函數(shù)往往會用上數(shù)個classes特性,那么它究竟該被置于何處呢?我們的原則是:判斷哪個class擁有最多[被此函數(shù)使用]的數(shù)據(jù),然后就把這個函數(shù)和那些數(shù)據(jù)擺在一起。如果先以Extract Method(110)將這個函數(shù)分解為數(shù)個較小函數(shù)并分別置放于不同地點,上述步驟也就比較容易完成了。

          有數(shù)個復(fù)雜精巧的模式(patterns)破壞了這個規(guī)則。說起這個話題,[四巨頭][Gang of Four]的StrategyVisitor立刻跳入我的腦海,Kent Beck的Self Delegation[Beck]也在此列。使用這些模式是為了對抗壞味道Divergent Change。最根本的原則是:將總是一起變化的東西放在一塊兒。[數(shù)據(jù)]和[引用這些數(shù)據(jù)]的行為總是一起變化的,但也有例外。如果例外出現(xiàn),我們就搬移那些行為,保持[變化只在一地發(fā)生]。StrategyVisitor使你得以輕松修改函數(shù)行為,因為它們將少量需被覆寫(overridden)的行為隔離開來-當(dāng)然也付出了[多一層間接性]的代價。
          posted on 2005-08-18 17:09 ivaneeo 閱讀(2286) 評論(0)  編輯  收藏 所屬分類: refactoring-從地獄中重生
          主站蜘蛛池模板: 抚顺县| 红河县| 牙克石市| 昌都县| 苏尼特左旗| 靖江市| 化德县| 伊春市| 湖口县| 光山县| 石河子市| 阜新市| 阳山县| 新田县| 大余县| 方城县| 宜丰县| 平定县| 泾阳县| 巴南区| 新乡县| 苏尼特右旗| 内丘县| 麻城市| 朝阳区| 南漳县| 盐津县| 江阴市| 拜城县| 海门市| 天峨县| 莫力| 怀柔区| 万安县| 宜宾市| 盐边县| 雷山县| 宾川县| 喀什市| 绥阳县| 陇川县|