• <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>

            Just enjoy programming

            c++設計模式(七) 職責鏈模式:嘗試采用一系列策略模式

                  職責鏈(Chain of Responsibility)模式也許被看做一個使用策略對象的“遞歸的動態一般化".此時提出一個調用,在一個鏈序列中的每個策略都試圖滿足這個調用。這個過程直到有一個策略成功滿足該調用或者到達序列的末尾才結束。在遞歸方法中,有個函數反復調用其自身至達到某個終止條件。在職責鏈中,一個函數調用自身,(通過遍歷策略鏈)調用函數的一個不同實現,如此反復直至達到某個終止條件。這個終止條件或者是已達到策略鏈的底部(這樣就會返回一個默認對象;不管能否提供這個默認結果,必須有個方法能夠決定該職責鏈搜索是成功還是失敗)或者是成功找到一個策略。
                 除了調用一個函數來滿足某個請求以外,鏈中的多個函數都有此機會滿足某個請求,因此它有點專家系統的意味。由于職責鏈實際上就是一個鏈表,它能夠動態創建,因此它可以看做是一個更一般的動態構建的switch語句。示例代碼如下:
            #include<iostream>
            #include<vector>

            using namespace std;


            enum Answer{NO,YES};

            class GimmeStrategy
            {
                public:
                    virtual Answer canIHave()=0;
                    virtual ~GimmeStrategy(){}
            };

            class AskMom: public GimmeStrategy
            {
                public:
                    Answer canIHave()
                    {
                        cout<<"Moom? can I have this?"<<endl;
                        return NO;
                    }
            };

            class AskDad: public GimmeStrategy
            {
                public:
                    Answer canIHave()
                    {
                        cout<<"Dad,I really need this!"<<endl;
                        return NO;
                    }
            };


            class AskGrandpa:public GimmeStrategy
            {
                public:
                    Answer canIHave()
                    {
                        cout<<"Grandpa , is it my birthday yet?"<<endl;
                        return NO;
                    }
            };

            class AskGrandma:public GimmeStrategy
            {
                public:
                    Answer canIHave()
                    {
                        cout<<"Grandma,I really love you!"<<endl;
                        return YES;
                    }
            };

            class Gimme:public GimmeStrategy
            {
                vector<GimmeStrategy*>chain;
                public:
                    Gimme(){
                        chain.push_back(new AskMom());
                        chain.push_back(new AskDad());
                        chain.push_back(new AskGrandpa());
                        chain.push_back(new AskGrandma());
                    }
                    Answer canIHave()
                    {
                        vector<GimmeStrategy*>::iterator it=chain.begin();
                        while(it!=chain.end())
                            if((*it++)->canIHave()==YES)
                                return YES;
                        cout<<"whiiiiiinnne!"<<endl;
                        return NO;
                    }
                    ~Gimme(){};
            };

            int main()
            {
                Gimme chain;
                chain.canIHave();
            }


            參考 :c++編程思想卷二

            posted on 2011-05-03 14:01 周強 閱讀(671) 評論(1)  編輯 收藏 引用 所屬分類: c/c++

            評論

            # re: c++設計模式(七) 職責鏈模式:嘗試采用一系列策略模式 2013-01-19 11:33 hailong

            明顯有指針泄露。  回復  更多評論   

            av无码久久久久久不卡网站| 看全色黄大色大片免费久久久| 无码专区久久综合久中文字幕| 久久精品国产网红主播| 国产精品综合久久第一页| 久久久久无码国产精品不卡| 热99RE久久精品这里都是精品免费 | 久久亚洲精品国产精品| 青青草国产精品久久久久| 少妇被又大又粗又爽毛片久久黑人| 久久午夜夜伦鲁鲁片免费无码影视| 久久久久人妻一区二区三区vr| 国产一区二区精品久久凹凸| 久久综合给合久久狠狠狠97色69| 久久久久亚洲AV无码专区桃色| 精品免费久久久久久久| 亚洲伊人久久成综合人影院| 欧美亚洲国产精品久久蜜芽| 午夜久久久久久禁播电影 | 综合久久给合久久狠狠狠97色| 久久久久国产一级毛片高清版| 国内精品久久久久久久久电影网 | 色综合久久天天综线观看| 国产精品禁18久久久夂久| 久久久久久久综合狠狠综合| 久久久久国产成人精品亚洲午夜| 97久久香蕉国产线看观看| 亚洲愉拍99热成人精品热久久| 一级a性色生活片久久无少妇一级婬片免费放| 狠狠色丁香久久综合五月| 欧美午夜精品久久久久免费视| 亚洲愉拍99热成人精品热久久| 国内高清久久久久久| 久久婷婷色综合一区二区| 久久99热这里只频精品6| 久久精品综合网| 亚洲人成伊人成综合网久久久| 伊人久久综合精品无码AV专区| 99久久夜色精品国产网站| 国产A级毛片久久久精品毛片| 亚洲狠狠婷婷综合久久久久|