• <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>
            隨筆 - 8, 文章 - 0, 評(píng)論 - 17, 引用 - 0
            數(shù)據(jù)加載中……

            觀察者模式(Subject/Observer)

            定義:對(duì)象間的一對(duì)多的依賴關(guān)系,當(dāng)一個(gè)對(duì)象的狀態(tài)發(fā)生改變時(shí),所有依賴于它的對(duì)象都得到通知并被自動(dòng)更新。 

            功能:搜索數(shù)據(jù)庫(kù),當(dāng)有需要公布的數(shù)據(jù)將其用各種方式發(fā)送出去。
             
            觀察者模式無(wú)疑能很好的做到上面的要求,無(wú)論要多少種方式,只要增加多個(gè)繼承之ITransfer接口的派生類即可,有很好的維護(hù)性。

            以下是實(shí)際的應(yīng)用.



            //接口
            //ITransfer.h
            #pragma once

            class ITransfer
            {
            public:
                
            virtual bool DoTransfer(...= 0;
            }
            ;


            //FetionTransfer.h
            #pragma once
               #include "Transfer.h"
            class CFetionTransfer:public ITransfer
            {
            public:
                CFetionTransfer();
                
            ~CFetionTransfer();
                
            bool DoTransfer(...);
            private:
                ......
            }
            ;


            //MailTransfer.h
            #pragma once
               #include "Transfer.h"
            class CMailTransfer: public ITransfer
            {
            public:
                CMailTransfer();
                
             ~CMailTransfer();
                
            bool DoTransfer(...);
            private:
            ....
            }
            ;


            //TransferPool.h
            #pragma once

            #include 
            "Transfer.h"
            #include 
            <vector>
            using namespace std;

            class CTransferPool
            {
            private:
                vector
            <ITransfer*> vo;
            public:
                
            virtual ~CTransferPool();

                
            void Login(ITransfer* po);

                
            void Logout(ITransfer* po);
               
            //向各成員廣播消息
                void Notify(...);
            }
            ;

            //TransferPool.cpp
            #include "TransferPool.h"

            CTransferPool::
            ~CTransferPool()
            {
                vector
            <ITransfer*>::iterator vi = vo.begin();
                
            for (; vi != vo.end(); vi++)
                
            {
                             if(*vi)
                                {
                                    delete *vi;
                                     *vi = NULL;
                                }

                }

            }


            void CTransferPool::Login(ITransfer* po)
            {
                vo.push_back(po);
            }


            void CTransferPool::Logout(ITransfer* po)
            {
                vector
            <ITransfer*>::iterator vi = vo.begin();
                
            for (; vi != vo.end(); vi++)
                
            {
                    
            if (*vi == po)
                        vo.erase(vi);
                }

            }


            void CTransferPool::Notify(...)
            {
                vector
            <ITransfer*>::iterator vi = vo.begin();
                
            for (; vi != vo.end(); vi++)
                
            {
                    ITransfer 
            *= *vi;
                        
                    (
            *vi)->DoTransfer(...);
                }

            }


            void main
            {
                CTransferPool
            *m_pTranPool= new CTransferPool();
                
                CFetionTransfer 
            *m_pFetionTran = new CFetionTransfer(...);
                CMailTransfer 
            *m_pMailTran = new CMailTransfer(...);

                m_pTranPool
            ->Login(m_pFetionTran);
                m_pTranPool
            ->Login(m_pMailTran);
                   
                    
            while(需要發(fā)送消息)
                    
            {
                        m_pTranPool
            ->Notify();
                    }


                    
            //釋放
                      if(m_pTranPool)
                    
            {
                        delete m_pTranPool;
                        m_pTranPool 
            = NULL;
                    }


            }

            posted on 2008-08-29 15:49 YG 閱讀(1812) 評(píng)論(5)  編輯 收藏 引用 所屬分類: C/C++ & 設(shè)計(jì)模型

            評(píng)論

            # re: 觀察者模式(Subject/Observer)   回復(fù)  更多評(píng)論   

            恩,受益匪淺,謝謝
            2008-08-29 18:46 | 鄒從杰

            # re: 觀察者模式(Subject/Observer)   回復(fù)  更多評(píng)論   

            比《設(shè)計(jì)模式》上的例子容易理解些。
            附上觀察者模式的定義:
            定義對(duì)象間的一對(duì)多的依賴關(guān)系,當(dāng)一個(gè)對(duì)象的狀態(tài)發(fā)生改變時(shí),所有依賴于它的對(duì)象都得到通知并被自動(dòng)更新。
            2008-08-29 19:09 | ronliu

            # re: 觀察者模式(Subject/Observer)   回復(fù)  更多評(píng)論   

            唉,還是很麻煩很麻煩。。。。
            2008-08-29 21:26 | 空明流轉(zhuǎn)

            # re: 觀察者模式(Subject/Observer)   回復(fù)  更多評(píng)論   

            不錯(cuò)....
            2008-08-30 15:25 | ci

            # re: 觀察者模式(Subject/Observer)   回復(fù)  更多評(píng)論   

            呵呵,以前做項(xiàng)目時(shí)用過(guò)這種模式,只是當(dāng)時(shí)并不知道這就是觀察著模式,正可是“不知廬山真面目,只緣身在此山中”
            2009-02-04 09:35 | nirvana
            久久亚洲国产最新网站| 久久青青草原亚洲av无码app| 久久久精品免费国产四虎| 精品久久久久久久| 久久99精品国产麻豆蜜芽| 久久久久成人精品无码| 亚洲综合久久夜AV | 狠色狠色狠狠色综合久久| 99久久精品免费国产大片| 青青草原综合久久大伊人导航| 99久久精品国产一区二区| 久久久久久亚洲Av无码精品专口| 久久免费国产精品一区二区| 国产精品激情综合久久| 色综合合久久天天给综看| 久久久免费精品re6| 久久婷婷色香五月综合激情| 国产精品一久久香蕉国产线看| 久久久噜噜噜久久中文字幕色伊伊| 无码8090精品久久一区| 国产精品免费久久久久久久久 | 久久er国产精品免费观看2| 精品久久久久中文字幕一区| 一本一本久久A久久综合精品| 中文精品久久久久国产网址| 国色天香久久久久久久小说| 久久av高潮av无码av喷吹| 久久亚洲AV成人出白浆无码国产| 欧美亚洲日本久久精品| 观看 国产综合久久久久鬼色 欧美 亚洲 一区二区 | 久久无码中文字幕东京热| 精品久久综合1区2区3区激情| 婷婷久久综合九色综合98| 国产亚洲综合久久系列| 亚洲精品无码专区久久久| 漂亮人妻被中出中文字幕久久| 久久久中文字幕| 97久久精品无码一区二区| 精品午夜久久福利大片| 久久一日本道色综合久久| 香蕉久久av一区二区三区|