• <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++博客 :: 首頁 :: 聯系 :: 聚合  :: 管理
              140 Posts :: 1 Stories :: 11 Comments :: 0 Trackbacks

            常用鏈接

            留言簿(1)

            我參與的團隊

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

            設計模式學習總結之五

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

             (注2)假設有這樣的一個問題存在(其實現實開發中,非常經常遇到):基類BasicClassX有N個的派生類。因為它們沒有功能接口void UnknowFunction(void);
            按正常的。我們的處理方法,(1) 可以通過直接修改BasicClassX基類,在此添加virtual void UnknowFunction(void);虛接口并實現,然后所有derived
            class中均可見。(2) 又或是在BasicClassX基類,添加了純虛接口,然后在具體某派生類中進行了實現。在實現使用中,用該derived class來處理。
             (注3)但這樣做會有這樣的問題存在:a) 會有可能讓繼承的深度,變的很深。系統的類將變的很多,很復雜。b) 類的結構也將變的復雜化。(因為現
            在是增加個接口,以后要是又有其他的接口功能需要添加了???) c) 無形中,會加重基類的負擔。因為必須得保證擴展該接口,否則基類看不到該接
            口。
             (注1)為了解決上面的問題。Decorator模式就可以幫助我們很輕松地解決。我們實現一個Decorator類。該類,只要引用一個BasicClassX指針對象即可。
            然后在Decorator類中,擴展功能接口,這樣,新擴展的功能就與BasicClassX的相關類,無任何關系。只是在BasicClassX相關類需要該擴展接口的地方,
            使用Decorator類來處理即可。就相當于BasicClassX的對象(或是它的derived class object)委托Decorator來實現處理一樣。但又同時像是將BasicClassX
            對象與Decorator對象進行組合在一起使用。從而達到新接口的擴展作用。Decorator模式就是這么回事。
             下面簡要提煉下Decorator類的設計
             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;
             }
             個人認為,Decorator模式,你說它有用。它確實有用。說它沒用。其實它也沒用。為啥這樣說了?因為它完全可以通過,繼承,或者直接修改原有的類體系來
            實現。但它的存在,也確實會讓系統的思路清晰些。至少代碼相對不會那么亂。

            posted on 2011-05-17 01:16 Jacc.Kim 閱讀(303) 評論(0)  編輯 收藏 引用 所屬分類: 設計模式
            久久天天躁狠狠躁夜夜不卡| 97精品伊人久久大香线蕉app| 久久久黄片| 久久精品国产久精国产果冻传媒| 亚洲精品第一综合99久久| 久久精品a亚洲国产v高清不卡| 久久久国产精品福利免费| 人妻系列无码专区久久五月天| 久久人爽人人爽人人片AV| 久久精品国产一区二区电影| 中文国产成人精品久久不卡| 久久91精品综合国产首页| 一本一道久久综合狠狠老 | 久久99精品久久久久久水蜜桃| 无码国内精品久久人妻麻豆按摩| 成人久久精品一区二区三区| 久久只有这里有精品4| 99精品久久久久久久婷婷| 久久亚洲AV成人无码电影| 久久人人爽人人爽AV片| 99久久伊人精品综合观看| 久久人人爽人人爽人人AV| 色综合合久久天天给综看| 国产精品成人精品久久久| 国内精品久久久久久99| 亚洲av伊人久久综合密臀性色| 少妇久久久久久被弄到高潮| 中文精品久久久久国产网址| 久久99精品久久只有精品| 麻豆成人久久精品二区三区免费| 久久天天躁狠狠躁夜夜2020 | 99久久免费只有精品国产| 国产精品久久久久久吹潮| 久久人人爽人人爽人人片AV麻烦 | 亚洲AV无码一区东京热久久| 99精品国产免费久久久久久下载| 久久嫩草影院免费看夜色| 国产欧美久久久精品影院| 日产精品久久久久久久| 狠狠色综合网站久久久久久久高清| 久久午夜福利电影|