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

            我參與的團隊

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

            Mediator模式
                  該模型主要解決兩個或多個對象間的相互通信的問題。(個人認為該模式的思想同Observer模式的思想還是有點類似的。表面上看,他們所解決的問題類型根本不同,那為什么我會這么認為了?后面再說明)。按理說,各對象間的通信假如:ObjA與ObjB要進行通信。方法有好多種。比如:可以在它們內部各存一份對方的引用。在一方變動時,調用另一方進行同步即可。但確實如果系統大而復雜時,這將顯示的不那么清晰。因此,就希望中間會有個調停者。Mediator模式就因此而生。此時,ObjA與ObjB內部只存為一份Mediator(MediatorObj)對象的引用。在對象變動時,只需調用MediatorObj的相關接口,通知其他對象需要同步更新即可。因此,對ObjA或ObjB或其他的任何對象來說,它們有可能根本不知道還有其他的對象存在。(如:ObjA可能不知道ObjB的存在。)但通過MediatorObj對象,卻達到了ObjA與ObjB的同步作用。(現在想下,是不是與Observer模式有點類似?因為,如果在Observer模式的實現上,抽象出一個IObserverable來。那通過IObserverable對象,可以通知所有View的更新)。
             

            class CClassA;
            class CClassB;

            class CMediator
            {
            public:
                CMediator(){}
                CMediator(CClassA
            * pObjA, CClassB* pObjB)
                {
                    
            this->m_pObjA = pObjA;
                    
            this->m_pObjB = pObjB;
                }
                
            void DoSyncFromAToB(void)
                {
                    
            this->m_pObjB->xxx
                }
                
            void DoSyncFromBToA(void)
                {
                    
            this->m_pObjA->xxx
                }
            private:
                CClassA
            * m_pObjA;
                CClassB
            * m_pObjB;
            };

            class CClassA
            {
            public:
                CClassA(){}
                CClassA(CMediator
            * pMediator)
                {
                    
            this->m_pMediator = pMediator;
                }
                
            void DoAction(void)
                {
                    
            // do some work here
                    
                    
            // 通知其他對象,需要同步
                    this->m_pMediator->DoSyncFromAToB();
                }

            private:
                CMediator
            * m_pMediator;
            };

            class CClassB
            {
            public:
                CClassB(){}
                CClassB(CMediator
            * pMediator)
                {
                    
            this->m_pMediator = pMediator;
                }
                
            void DoAction(void)
                {
                    
            // do some work here
                    
                    
            // 通知其他對象,需要同步
                    this->m_pMediator->DoSyncFromBToA();
                }

            private:
                CMediator
            * m_pMediator;
            };
            posted on 2011-06-28 10:26 Jacc.Kim 閱讀(1026) 評論(0)  編輯 收藏 引用 所屬分類: 設計模式
            亚洲欧美成人久久综合中文网| 久久不见久久见免费影院www日本| 国产精品嫩草影院久久| 国产99久久九九精品无码| 97热久久免费频精品99| 国产L精品国产亚洲区久久| 国产伊人久久| 日本强好片久久久久久AAA| 一级做a爰片久久毛片16| 久久精品国产一区二区 | 久久久久亚洲AV无码去区首| 亚洲人成无码网站久久99热国产| 亚洲精品国产综合久久一线| 久久久亚洲AV波多野结衣| 精品久久一区二区| 色狠狠久久综合网| 精品久久人妻av中文字幕| 久久久青草青青国产亚洲免观| 色欲综合久久躁天天躁蜜桃| 婷婷久久综合九色综合绿巨人| 亚洲国产精品久久久久| 无码久久精品国产亚洲Av影片| 国产精品免费久久久久影院| 9久久9久久精品| 久久久久亚洲爆乳少妇无| 欧美国产成人久久精品| 久久这里只有精品18| 精品久久人人妻人人做精品| 久久66热人妻偷产精品9| 久久精品中文騷妇女内射| 亚洲&#228;v永久无码精品天堂久久 | 久久久亚洲AV波多野结衣| 97精品伊人久久大香线蕉| 久久久免费精品re6| 久久精品无码专区免费东京热| 久久婷婷五月综合色高清| 久久精品国产亚洲5555| 久久国产色AV免费观看| 合区精品久久久中文字幕一区| 日韩人妻无码精品久久免费一| 亚洲国产二区三区久久|