《重構(gòu)》學(xué)習(xí)筆記

最近在讀《重構(gòu)》這本書,試著把書中對(duì)我啟發(fā)較大的一些點(diǎn)記錄下來(lái),以便回顧學(xué)習(xí)昔搂。

一、replace temp with query(以查詢?nèi)〈R時(shí)變量)

在寫程序的過(guò)程中输拇,難免會(huì)在函數(shù)中定義一些臨時(shí)變量摘符,有些時(shí)候是無(wú)法避免的。但因?yàn)榕R時(shí)變量可能使用起來(lái)簡(jiǎn)單策吠、快捷议慰,因而有時(shí)會(huì)出現(xiàn)不恰當(dāng)?shù)氖褂谩R驗(yàn)橛行┡R時(shí)變量在定義之后只進(jìn)行了一次賦值奴曙,那么這種臨時(shí)變量是否有存在的價(jià)值就值得考慮别凹。把臨時(shí)相關(guān)的賦值操作抽象為一個(gè)函數(shù),以一個(gè)恰當(dāng)?shù)暮瘮?shù)名命名這個(gè)函數(shù)洽糟,那么便可將相應(yīng)的計(jì)算封裝起來(lái)炉菲,這樣計(jì)的算規(guī)則封裝在一個(gè)函數(shù)中堕战,可以將變化隔離獨(dú)立出來(lái),便于修改拍霜。

以書中的一段代碼為例:

  double getPrice(){
      int basePrice = _quantity * _itemPrice;
      double discountFactor;
      if(basePrice > 1000) {
          discountFactor = 0.95;
      } else {
         discountFactor = 0.98;
     }
     return baseprice * discountFactor;
   }

重構(gòu)后的代碼為:

    double getPrice(){
        return baseprice() * discountFactor();
    }  
    int basePrice() {
        return _quantity * _itemPrice;
    }
    double discountFactor() {
        if(basePrice() > 1000) {
           return 0.95;
        } else {
            return 0.98;
        }
    }

個(gè)人認(rèn)為這樣做的好處是basePrice和discountFactor的計(jì)算都隔離出來(lái)嘱丢,如果發(fā)生變化容易修改。此外祠饺,discountFactor()函數(shù)的1000,0.95等數(shù)字的可以通過(guò)常量的方式定義越驻,更加合理一點(diǎn)。


二道偷、replace method with method object(以函數(shù)對(duì)象取代函數(shù))

  • 有時(shí)缀旁,可能會(huì)出現(xiàn)某個(gè)函數(shù)特別復(fù)雜,里面有大量的臨時(shí)變量以及復(fù)雜的運(yùn)算勺鸦,那么我們可以采用“以函數(shù)對(duì)象取代函數(shù)”的方法來(lái)對(duì)這個(gè)復(fù)雜的函數(shù)內(nèi)容進(jìn)行重構(gòu)并巍。

  • 做法為將復(fù)雜的函數(shù)中使用到的臨時(shí)變量作為函數(shù)對(duì)象(MethodObject)的成員變量,原先函數(shù)中復(fù)雜的計(jì)算封裝到函數(shù)對(duì)象的某一個(gè)方法中(如compute())换途。

  • 這樣即可以在原先復(fù)雜的函數(shù)中以new MethodObject(...).compute();取代原先的代碼懊渡。這樣的好處在于這段復(fù)雜的代碼方便復(fù)用、重構(gòu)以及變更军拟。

三剃执、Hide Delegate(隱藏委托關(guān)系)

  • 首先是隱藏“委托關(guān)系”
有時(shí)客戶端需要先通過(guò)服務(wù)對(duì)象A的方法得到另一個(gè)對(duì)象B,然后再調(diào)用B的函數(shù)b懈息,這會(huì)產(chǎn)生一個(gè)“級(jí)聯(lián)調(diào)用”肾档。
有時(shí)我們需要隱藏這種“關(guān)系”,我們可以在在服務(wù)對(duì)象A上放置一個(gè)簡(jiǎn)單的“委托函數(shù)”a漓拾,在函數(shù)a的內(nèi)部調(diào)用B的函數(shù)b。
這樣的話客戶端只需要調(diào)用A對(duì)象的a函數(shù)即可戒祠。

《重構(gòu)》書中給出的例子如下:

class Person {
    private Department department;
    public Department getDepartment() {
        return this.department;
    }
    public void setDepartment(Department department) {
        this.department = department;
    }
}

class Department {
    private String code;
    private Person manager;
    public Department(Person manager) {
        this.manager = manager;
    }
    public Person getPerson() {
        return this.manager;
    }
}
  • 調(diào)用場(chǎng)景及問(wèn)題如下如下:
要獲取某部門的經(jīng)理:manager = john.getDepartment().getManager();
這樣的調(diào)用會(huì)暴露內(nèi)部實(shí)現(xiàn)骇两,并且調(diào)用端會(huì)和Department類產(chǎn)生耦合。
  • 解決辦法:
在Person類中添加一個(gè)委托方法:
public Person getManager() {
    return department.getManager();
}
manager = john.getManager();
這樣調(diào)用端就不需要知道Department類的信息姜盈,Department類發(fā)生變化時(shí)只需要通知Person類即可低千,易于維護(hù)。
  • 額外說(shuō)明:
當(dāng)服務(wù)端的委托函數(shù)過(guò)多時(shí)馏颂,可能之前的重構(gòu)方案出現(xiàn)問(wèn)題示血,需要采用新的重構(gòu)方案。
如讓客戶端依賴受委托的對(duì)象救拉。

當(dāng)然难审,進(jìn)行重構(gòu)時(shí)還應(yīng)該具體情況具體分析。

持續(xù)更新

如有不正確的地方亿絮,歡迎指出告喊!謝謝大家麸拄!

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市黔姜,隨后出現(xiàn)的幾起案子拢切,更是在濱河造成了極大的恐慌,老刑警劉巖秆吵,帶你破解...
    沈念sama閱讀 206,311評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件淮椰,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡纳寂,警方通過(guò)查閱死者的電腦和手機(jī)主穗,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,339評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)烈疚,“玉大人黔牵,你說(shuō)我怎么就攤上這事∫危” “怎么了猾浦?”我有些...
    開封第一講書人閱讀 152,671評(píng)論 0 342
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)灯抛。 經(jīng)常有香客問(wèn)我金赦,道長(zhǎng),這世上最難降的妖魔是什么对嚼? 我笑而不...
    開封第一講書人閱讀 55,252評(píng)論 1 279
  • 正文 為了忘掉前任夹抗,我火速辦了婚禮,結(jié)果婚禮上纵竖,老公的妹妹穿的比我還像新娘漠烧。我一直安慰自己,他們只是感情好靡砌,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,253評(píng)論 5 371
  • 文/花漫 我一把揭開白布已脓。 她就那樣靜靜地躺著,像睡著了一般通殃。 火紅的嫁衣襯著肌膚如雪度液。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,031評(píng)論 1 285
  • 那天画舌,我揣著相機(jī)與錄音堕担,去河邊找鬼。 笑死曲聂,一個(gè)胖子當(dāng)著我的面吹牛霹购,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播朋腋,決...
    沈念sama閱讀 38,340評(píng)論 3 399
  • 文/蒼蘭香墨 我猛地睜開眼厕鹃,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼兢仰!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起剂碴,我...
    開封第一講書人閱讀 36,973評(píng)論 0 259
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤把将,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后忆矛,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體察蹲,經(jīng)...
    沈念sama閱讀 43,466評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,937評(píng)論 2 323
  • 正文 我和宋清朗相戀三年催训,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了洽议。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,039評(píng)論 1 333
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡漫拭,死狀恐怖亚兄,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情采驻,我是刑警寧澤瘪撇,帶...
    沈念sama閱讀 33,701評(píng)論 4 323
  • 正文 年R本政府宣布患朱,位于F島的核電站,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏茸俭。R本人自食惡果不足惜团秽,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,254評(píng)論 3 307
  • 文/蒙蒙 一偷霉、第九天 我趴在偏房一處隱蔽的房頂上張望虏辫。 院中可真熱鬧,春花似錦汰翠、人聲如沸龄坪。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,259評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)健田。三九已至,卻和暖如春苟穆,著一層夾襖步出監(jiān)牢的瞬間抄课,已是汗流浹背唱星。 一陣腳步聲響...
    開封第一講書人閱讀 31,485評(píng)論 1 262
  • 我被黑心中介騙來(lái)泰國(guó)打工雳旅, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人间聊。 一個(gè)月前我還...
    沈念sama閱讀 45,497評(píng)論 2 354
  • 正文 我出身青樓攒盈,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親哎榴。 傳聞我的和親對(duì)象是個(gè)殘疾皇子型豁,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,786評(píng)論 2 345

推薦閱讀更多精彩內(nèi)容

  • 《重構(gòu)》讀書筆記 總覽 第一部分 第一章從實(shí)例程序出發(fā)僵蛛,展示設(shè)計(jì)的缺陷,對(duì)其重構(gòu)可以了解重構(gòu)的過(guò)程和方法迎变。 第二部...
    白樺葉閱讀 2,378評(píng)論 2 5
  • Extract Method 提煉方法 動(dòng)機(jī) Extract Method 是最常用的重構(gòu)手法之一充尉。 函數(shù)過(guò)長(zhǎng)或者...
    chiguozi閱讀 746評(píng)論 0 0
  • Android 自定義View的各種姿勢(shì)1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 171,504評(píng)論 25 707
  • 轉(zhuǎn)自微信公眾號(hào):云水婷心(ystx1016) 在人的一生當(dāng)中會(huì)遇到許多人,有的人與你僅僅只是一面之緣衣形,卻在你的生命...
    云水婷心_1016閱讀 221評(píng)論 0 1
  • 01 來(lái)到這座城市已經(jīng)一年之久驼侠,多變的天氣對(duì)于我來(lái)說(shuō),就像是一種挑釁谆吴。 Jack倒源,是一家酒吧的老板,也是我這座城市...
    慕玉珩閱讀 441評(píng)論 2 4