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

            常用鏈接

            留言簿(18)

            我參與的團隊

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

            橋接模式的意圖是將抽象部分與實現部分分離,使它們都可以獨立的變化。
            先附上其結構圖:


            以一個日志記錄工具這個例子來說明Bridge模式,現在我們要開發一個通用的日志記錄工具,它支持數據庫記錄DatabaseLog和文本文件記錄FileLog兩種方式,同時它既可以運行在.NET平臺,也可以運行在Java平臺上。
            我們把日志記錄方式和不同平臺上的實現分別當作兩個獨立的部分來對待,Log及ImpLog,Log是日志記錄方式,ImpLog是日志記錄在不同平臺的實現的基類,結構圖如下:


            實現代碼:
            //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 
            << "數據庫日志:";
                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;
            }

            最后輸出為:
            數據庫日志:在.NET下寫日志
            文本日志:在.NET下寫日志
            數據庫日志:在Java下寫日志
            文本日志:在Java下寫日志

            更詳細信息請參考:http://terrylee.cnblogs.com/archive/2006/02/24/336652.html
            posted on 2009-02-10 11:02 emptysoul 閱讀(1010) 評論(0)  編輯 收藏 引用
            欧美伊人久久大香线蕉综合| 国产麻豆精品久久一二三| 精品久久久久久99人妻| 亚洲AV伊人久久青青草原| 无码人妻久久一区二区三区蜜桃| 7777久久久国产精品消防器材| 国产精品天天影视久久综合网| 久久91综合国产91久久精品 | 国产精品中文久久久久久久| 亚洲精品乱码久久久久久| 久久精品国产99国产精偷| 久久久无码精品亚洲日韩京东传媒 | 91久久九九无码成人网站| 久久人与动人物a级毛片| 97久久精品人人澡人人爽| 嫩草影院久久国产精品| 色8激情欧美成人久久综合电| 久久精品亚洲福利| 午夜精品久久久久久影视riav| 亚洲AV日韩AV天堂久久| 99久久国产免费福利| 久久亚洲AV成人出白浆无码国产| 青青热久久国产久精品| 青青草国产精品久久久久| 蜜臀av性久久久久蜜臀aⅴ麻豆 | 青青草国产精品久久| 久久亚洲私人国产精品| 久久国产AVJUST麻豆| 亚洲精品97久久中文字幕无码| 精品无码久久久久久久动漫| 欧美精品一区二区精品久久| 99久久99久久久精品齐齐 | 久久97精品久久久久久久不卡| 一本色道久久综合狠狠躁| 精品久久久久久无码不卡| 一级女性全黄久久生活片免费 | 无码国内精品久久人妻麻豆按摩| 国产亚洲美女精品久久久| 99热精品久久只有精品| 国产ww久久久久久久久久| 久久99精品久久久久久噜噜|