• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            積木

            No sub title

              C++博客 :: 首頁(yè) :: 聯(lián)系 :: 聚合  :: 管理
              140 Posts :: 1 Stories :: 11 Comments :: 0 Trackbacks

            常用鏈接

            留言簿(1)

            我參與的團(tuán)隊(duì)

            搜索

            •  

            最新評(píng)論

            閱讀排行榜

            評(píng)論排行榜

            設(shè)計(jì)模式學(xué)習(xí)總結(jié)之五

            七:Decorator模式(即:裝飾模式)

             (注2)假設(shè)有這樣的一個(gè)問(wèn)題存在(其實(shí)現(xiàn)實(shí)開發(fā)中,非常經(jīng)常遇到):基類BasicClassX有N個(gè)的派生類。因?yàn)樗鼈儧](méi)有功能接口void UnknowFunction(void);
            按正常的。我們的處理方法,(1) 可以通過(guò)直接修改BasicClassX基類,在此添加virtual void UnknowFunction(void);虛接口并實(shí)現(xiàn),然后所有derived
            class中均可見。(2) 又或是在BasicClassX基類,添加了純虛接口,然后在具體某派生類中進(jìn)行了實(shí)現(xiàn)。在實(shí)現(xiàn)使用中,用該derived class來(lái)處理。
             (注3)但這樣做會(huì)有這樣的問(wèn)題存在:a) 會(huì)有可能讓繼承的深度,變的很深。系統(tǒng)的類將變的很多,很復(fù)雜。b) 類的結(jié)構(gòu)也將變的復(fù)雜化。(因?yàn)楝F(xiàn)
            在是增加個(gè)接口,以后要是又有其他的接口功能需要添加了???) c) 無(wú)形中,會(huì)加重基類的負(fù)擔(dān)。因?yàn)楸仨毜帽WC擴(kuò)展該接口,否則基類看不到該接
            口。
             (注1)為了解決上面的問(wèn)題。Decorator模式就可以幫助我們很輕松地解決。我們實(shí)現(xiàn)一個(gè)Decorator類。該類,只要引用一個(gè)BasicClassX指針對(duì)象即可。
            然后在Decorator類中,擴(kuò)展功能接口,這樣,新擴(kuò)展的功能就與BasicClassX的相關(guān)類,無(wú)任何關(guān)系。只是在BasicClassX相關(guān)類需要該擴(kuò)展接口的地方,
            使用Decorator類來(lái)處理即可。就相當(dāng)于BasicClassX的對(duì)象(或是它的derived class object)委托Decorator來(lái)實(shí)現(xiàn)處理一樣。但又同時(shí)像是將BasicClassX
            對(duì)象與Decorator對(duì)象進(jìn)行組合在一起使用。從而達(dá)到新接口的擴(kuò)展作用。Decorator模式就是這么回事。
             下面簡(jiǎn)要提煉下Decorator類的設(shè)計(jì)
             SubClassA : BasicClassX;
             SubClassB : BasicClassX;
             SubClassC : SubClassA;
             ...
             SubClassN : ... : BasicClassX;

             class Decorator : BasicClassX
             {
             public:
              Decorator(BasicClassX* pBObj){m_pBOjb = pBObj;}
              void DoOperate(void)
              {
               m_pBObj->DoOperator();
               // do new interface
               this->DoNewInterfaceFunction();
              }
              //new extened interface function
              void DoNewInterfaceFunction(void){//do something...}
              // new extened other interface function
              ...
              
              //write down other code in here you knowned.
              ...
             private:
              BasicClassX* m_pBObj;
             }
             個(gè)人認(rèn)為,Decorator模式,你說(shuō)它有用。它確實(shí)有用。說(shuō)它沒(méi)用。其實(shí)它也沒(méi)用。為啥這樣說(shuō)了?因?yàn)樗耆梢酝ㄟ^(guò),繼承,或者直接修改原有的類體系來(lái)
            實(shí)現(xiàn)。但它的存在,也確實(shí)會(huì)讓系統(tǒng)的思路清晰些。至少代碼相對(duì)不會(huì)那么亂。

            posted on 2011-05-17 01:16 Jacc.Kim 閱讀(296) 評(píng)論(0)  編輯 收藏 引用 所屬分類: 設(shè)計(jì)模式
            国产成人久久精品二区三区| 91精品国产高清久久久久久91| 欧美亚洲另类久久综合婷婷| 免费一级欧美大片久久网| 亚洲婷婷国产精品电影人久久| 亚洲国产精品无码久久SM| 国产91久久精品一区二区| 久久精品亚洲欧美日韩久久| 伊人久久无码精品中文字幕| 高清免费久久午夜精品| 久久只有这里有精品4| 欧美精品一区二区精品久久 | 久久精品亚洲精品国产欧美| 中文精品久久久久人妻不卡| 九九热久久免费视频| 久久精品国产99久久久| 美女久久久久久| 91亚洲国产成人久久精品| 久久久久久亚洲AV无码专区| 欧美日韩成人精品久久久免费看| 人妻无码中文久久久久专区| 精品国产日韩久久亚洲| 久久国产热这里只有精品| 精品久久久久久久久中文字幕| 亚洲伊人久久精品影院| 人妻精品久久久久中文字幕| 国产成人精品久久亚洲高清不卡| 俺来也俺去啦久久综合网| 亚洲AV无码久久精品色欲| 伊人久久大香线蕉综合网站| 热久久国产欧美一区二区精品| 国产成人精品久久综合 | 国产精品9999久久久久| 色综合久久久久久久久五月| 综合久久一区二区三区| 久久只有这里有精品4| 久久WWW免费人成一看片| 国产99久久久国产精品小说| 国产免费久久精品99re丫y| 国产一区二区久久久| 97久久婷婷五月综合色d啪蜜芽 |