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

            emptysoul

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

            常用鏈接

            留言簿(18)

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

            搜索

            •  

            最新評(píng)論

            閱讀排行榜

            評(píng)論排行榜

            橋接模式的意圖是將抽象部分與實(shí)現(xiàn)部分分離,使它們都可以獨(dú)立的變化。
            先附上其結(jié)構(gòu)圖:


            以一個(gè)日志記錄工具這個(gè)例子來(lái)說(shuō)明Bridge模式,現(xiàn)在我們要開(kāi)發(fā)一個(gè)通用的日志記錄工具,它支持?jǐn)?shù)據(jù)庫(kù)記錄DatabaseLog和文本文件記錄FileLog兩種方式,同時(shí)它既可以運(yùn)行在.NET平臺(tái),也可以運(yùn)行在Java平臺(tái)上。
            我們把日志記錄方式和不同平臺(tái)上的實(shí)現(xiàn)分別當(dāng)作兩個(gè)獨(dú)立的部分來(lái)對(duì)待,Log及ImpLog,Log是日志記錄方式,ImpLog是日志記錄在不同平臺(tái)的實(shí)現(xiàn)的基類,結(jié)構(gòu)圖如下:


            實(shí)現(xiàn)代碼:
            //ImpLog.h
            class ImpLog  
            {
            public:
                
            virtual ~ImpLog();

                
            virtual void WriteLog() = 0;
            protected:
                ImpLog();
            };

            //ImpLog.cpp
            #include "stdafx.h"
            #include 
            "ImpLog.h"

            ImpLog::ImpLog()
            {

            }

            ImpLog::
            ~ImpLog()
            {

            }

            //NImpLog.h
            #include "ImpLog.h"

            class NImpLog : public ImpLog
            {
            public:
                NImpLog();
                
            virtual ~NImpLog();

                
            void WriteLog();
            };

            //NImpLog.cpp
            #include "stdafx.h"
            #include 
            "NImpLog.h"
            #include 
            <iostream>

            using namespace std;

            NImpLog::NImpLog()
            {

            }

            NImpLog::
            ~NImpLog()
            {

            }

            void NImpLog::WriteLog()
            {
                cout 
            << "在.NET下寫日志" << endl;
            }

            //JImpLog.h
            #include "ImpLog.h"

            class JImpLog : public ImpLog
            {
            public:
                JImpLog();
                
            virtual ~JImpLog();

                
            void WriteLog();
            };

            //JImpLog.cpp
            #include "stdafx.h"
            #include 
            "JImpLog.h"
            #include 
            <iostream>

            using namespace std;

            JImpLog::JImpLog()
            {

            }

            JImpLog::
            ~JImpLog()
            {

            }

            void JImpLog::WriteLog()
            {
                cout 
            << "在Java下寫日志" << endl;
            }

            //Log.h
            class ImpLog;
            class Log
            {
            public:
                
            virtual ~Log();

                
            virtual void Write() = 0;
            protected:
                Log();
            };

            //Log.cpp
            #include "stdafx.h"
            #include 
            "Log.h"

            Log::Log()
            {

            }

            Log::
            ~Log()
            {

            }

            //DBLog.h
            #include "Log.h"

            class DBLog : public Log
            {
            public:
                DBLog();
                DBLog(ImpLog
            *);
                
            virtual ~DBLog();

                
            void Write();
            private:
                ImpLog
            * m_pImpLog;
            };

            //DBLog.cpp
            #include "stdafx.h"
            #include 
            "DBLog.h"
            #include 
            "ImpLog.h"
            #include 
            <iostream>

            using namespace std;

            DBLog::DBLog()
            {
                
            }

            DBLog::DBLog(ImpLog
            * pImpLog) : m_pImpLog(pImpLog)
            {
                
            }

            DBLog::
            ~DBLog()
            {
                
            if(m_pImpLog != NULL)
                {
                    delete m_pImpLog;
                    m_pImpLog 
            = NULL;
                }
            }

            void DBLog::Write()
            {
                cout 
            << "數(shù)據(jù)庫(kù)日志:";
                m_pImpLog
            ->WriteLog();
            }

            //TxtLog.h
            #include "Log.h"

            class TxtLog : public Log  
            {
            public:
                TxtLog();
                TxtLog(ImpLog
            *);
                
            virtual ~TxtLog();

                
            void Write();
            private:
                ImpLog
            * m_pImpLog;
            };

            //TxtLog.cpp
            #include "stdafx.h"
            #include 
            "TxtLog.h"
            #include 
            "ImpLog.h"
            #include 
            <iostream>

            using namespace std;

            TxtLog::TxtLog()
            {
                
            }

            TxtLog::TxtLog(ImpLog
            * pImpLog) : m_pImpLog(pImpLog)
            {
                
            }

            TxtLog::
            ~TxtLog()
            {
                
            if(m_pImpLog != NULL)
                {
                    delete m_pImpLog;
                    m_pImpLog 
            = NULL;
                }
            }

            void TxtLog::Write()
            {
                cout 
            << "文本日志:";
                m_pImpLog
            ->WriteLog();
            }

            //main.cpp
            #include "stdafx.h"
            #include 
            "Log.h"
            #include 
            "DBLog.h"
            #include 
            "TxtLog.h"
            #include 
            "ImpLog.h"
            #include 
            "NImpLog.h"
            #include 
            "JImpLog.h"

            int main(int argc, char* argv[])
            {
                ImpLog
            * pImp = new NImpLog;
                Log
            * pLog = new DBLog(pImp);
                pLog
            ->Write();
                pLog 
            = new TxtLog(pImp);
                pLog
            ->Write();

                pImp 
            = new JImpLog;
                pLog 
            = new DBLog(pImp);
                pLog
            ->Write();
                pLog 
            = new TxtLog(pImp);
                pLog
            ->Write();

                
            return 0;
            }

            最后輸出為:
            數(shù)據(jù)庫(kù)日志:在.NET下寫日志
            文本日志:在.NET下寫日志
            數(shù)據(jù)庫(kù)日志:在Java下寫日志
            文本日志:在Java下寫日志

            更詳細(xì)信息請(qǐng)參考:http://terrylee.cnblogs.com/archive/2006/02/24/336652.html
            posted on 2009-02-10 11:02 emptysoul 閱讀(1008) 評(píng)論(0)  編輯 收藏 引用

            只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問(wèn)   Chat2DB   管理


            婷婷久久综合九色综合绿巨人| 久久人做人爽一区二区三区 | 久久久久久av无码免费看大片 | 久久精品国产亚洲一区二区| 精品久久久久香蕉网| 91久久精品91久久性色| 国产三级精品久久| 99久久99久久精品国产片果冻| 久久久久久九九99精品| 国产精品成人精品久久久| 国产精品美女久久福利网站| 91精品国产91久久久久福利| 欧美色综合久久久久久| 久久99热只有频精品8| 美女久久久久久| 久久综合九色综合久99| 亚洲Av无码国产情品久久| 精品国产乱码久久久久久1区2区 | 久久精品国产精品亚洲人人 | 精品国产乱码久久久久久郑州公司| 成人精品一区二区久久久| 久久精品一区二区三区AV| 亚洲精品国产成人99久久| 亚洲va久久久噜噜噜久久| 久久久精品国产Sm最大网站| 三上悠亚久久精品| 国内精品久久久久影院老司| 99久久99久久精品国产片| 久久人人爽人人爽人人AV| 武侠古典久久婷婷狼人伊人| 99久久国产综合精品网成人影院 | 国产A级毛片久久久精品毛片| 欧洲精品久久久av无码电影| 久久综合精品国产一区二区三区| 国产综合久久久久| 国产成年无码久久久久毛片| 无码人妻久久一区二区三区| 久久久国产打桩机| 99久久99久久精品国产片果冻| 久久久久黑人强伦姧人妻| 日韩久久久久中文字幕人妻|