• <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>
            隨筆 - 6  文章 - 11  trackbacks - 0
            <2009年7月>
            2829301234
            567891011
            12131415161718
            19202122232425
            2627282930311
            2345678

            常用鏈接

            留言簿(1)

            隨筆檔案

            搜索

            •  

            最新評(píng)論

            閱讀排行榜

            評(píng)論排行榜

            最近開發(fā)了一個(gè)基于ACE實(shí)現(xiàn)的C++ Service框架,每一個(gè)服務(wù)實(shí)現(xiàn)為一個(gè)插件,
            客戶端通過(guò)遠(yuǎn)程調(diào)用接口即可訪問(wèn)服務(wù)對(duì)象提供的服務(wù),客戶端接口的包裝如下所示:

            #pragma once
            #include 
            "CPPX_SessionIO.h"

            class CPPX_LoginService
            {
                
            class LoginRequest : public CPPX_Packet<LoginRequest>
                {
                
            public:
                    LoginRequest(
            void) : CPPX_Packet<LoginRequest>(*this) {}
                    
            string UserName;
                    
            string PassWord;
                    template
            <class Archive>
                    
            void serialize(Archive & ar, const unsigned int version){
                        ar 
            & UserName;
                        ar 
            & PassWord;
                    }
                };

                
            class LoginResult : public CPPX_Packet<LoginResult>
                {
                
            public:
                    LoginResult(
            void) : CPPX_Packet<LoginResult>(*this){}
                    
            bool success;
                    template
            <class Archive>
                    
            void serialize(Archive & ar, const unsigned int version){
                        ar 
            & success;
                    }
                };

                CPPX_SessionIO 
            & m_peer;

            public:
                CPPX_LoginService(CPPX_SessionIO 
            &peer) : m_peer(peer) {}

                
            bool apiUserLogin(string UserName,string PassWord){
                    LoginRequest login_request;
                    login_request.ServiceName 
            = "authsvc";
                    login_request.RequestType 
            = "apiUserLogin";
                    login_request.UserName    
            = UserName;
                    login_request.PassWord    
            = PassWord;
                    LoginResult login_result;
                    
            uint reuslt = m_peer.call(login_request,login_result);
                    
            return (reuslt==0)&&(login_result.success);
                }
            };



            一個(gè)網(wǎng)絡(luò)應(yīng)用一般包括兩部分,位于服務(wù)端的“服務(wù)對(duì)象”和位于客戶端的“調(diào)用代理”,上面這個(gè)類屬于客戶端代理對(duì)象。
            兩端之間遵從的協(xié)議就是請(qǐng)求“LoginRequest”和響應(yīng)“LoginResult ”。

            @欲三更

            非常對(duì),CPPX_LoginService就是用戶協(xié)議的封裝,屬于表示層范疇,其中的參數(shù)CPPX_SessionIO &peer屬于會(huì)話層對(duì)象,
            連接建立以后會(huì)返回一個(gè)peer對(duì)象,調(diào)用什么服務(wù)就創(chuàng)建一個(gè)響應(yīng)的服務(wù)對(duì)象,如調(diào)用CPPX_LoginService:

            void fuClientMainWindow::connect_open( CPPX_SessionIO &peer )
            {
                // 保存會(huì)話對(duì)象,以供主動(dòng)發(fā)送數(shù)據(jù)使用
                m_peer = peer;

               // 調(diào)用登錄服務(wù)
               CPPX_LoginService login_svc(peer);
                bool result = login_svc.apiUserLogin("funix","letmein");
            }

            CPPX_SessionIO 類是會(huì)話對(duì)象CPPX_Session的weak_ptr引用,weak_ptr是boost中定義的觀察者智能指針,利用boost::weak_ptr和boost::shared_ptr可以實(shí)現(xiàn)帶有引用計(jì)數(shù)的對(duì)象實(shí)例引用。

            #pragma once
            #include 
            "dllmain.h"
            #include 
            "CPPX_Packet.h"
            #include 
            <boost/scoped_ptr.hpp>

            class CPPX_Session;

            class CPPX_SVC_API CPPX_SessionIO
            {
                
            class pimpl_t;
                boost::scoped_ptr
            <pimpl_t> pimpl_;
                
            long m_session_id;

                
            /*
                 *    必須手動(dòng)定義析構(gòu)函數(shù),因?yàn)榫幾g器生成的隱式析構(gòu)函數(shù)時(shí),
                 *  pimpl_t類型還是不完整的,所以無(wú)法調(diào)用它的析構(gòu)函數(shù)。
                 
            */
            public:
                CPPX_SessionIO(
            void);
                
            ~CPPX_SessionIO(void);

            public:
                
            // 顯式構(gòu)造函數(shù):創(chuàng)建CPPX_Session的weak_ptr引用
                explicit CPPX_SessionIO(CPPX_Session * Session, long SessionID);

                
            /*
                 *    當(dāng)使用scoped_ptr作為類的成員時(shí),需要手動(dòng)定義這個(gè)類的copy constructor和copy assignment operator,
                 *  因?yàn)閟coped_ptr無(wú)法復(fù)制,因此聚集scoped_ptr的類也就不能進(jìn)行復(fù)制。
                 
            */
            public:
                
            // 拷貝構(gòu)造函數(shù):復(fù)制CPPX_Session的weak_ptr引用
                CPPX_SessionIO(const CPPX_SessionIO & copy);

                
            // 賦值操作符:監(jiān)聽器獲取會(huì)話引用,用戶建立連接時(shí)保存引用對(duì)象
                void operator = (const CPPX_SessionIO &copy);

            public:
                
            // 用于監(jiān)聽器查找會(huì)話引用,關(guān)閉連接時(shí)清除引用對(duì)象
                bool operator == (const CPPX_SessionIO &copy) const;

            public:
                
            // 狀態(tài)操作
                long getid(void);
                
            bool valid(void);
                
            void close(void);

                
            // 發(fā)送異步消息
                void send(const char *buffer,int length);
                
            void send(const string &message);
                
            void send(const char *message);

                
            // 等待會(huì)話返回該請(qǐng)求的響應(yīng)消息
                string expect(string service,string request);

                
            // 同步遠(yuǎn)程調(diào)用
                template<class PacketT,class ResultT>
                
            uint call(const CPPX_Packet<PacketT> & request, CPPX_Packet<ResultT> & result){
                    send(request.pack());
                    
            string response = expect(request.ServiceName,request.RequestType);
                    result.unpack(response);
                    
            return 0;
                }
            };

            #include "CPPX_SessionIO.h"
            #include 
            "CPPX_SessionIO_Pimpl.h"
            #include 
            <boost/shared_ptr.hpp>

            static CPPX_Session * null_session = 0;

            CPPX_SessionIO::CPPX_SessionIO( 
            void )
            : pimpl_(
            new pimpl_t(null_session)),
            m_session_id(
            0)
            {

            }

            CPPX_SessionIO::
            ~CPPX_SessionIO( void )
            {

            }

            CPPX_SessionIO::CPPX_SessionIO( CPPX_Session 
            * Session, long SessionID )
            : pimpl_(
            new pimpl_t(Session)),
            m_session_id(SessionID)
            {

            }

            CPPX_SessionIO::CPPX_SessionIO( 
            const CPPX_SessionIO & copy )
            : pimpl_(
            new pimpl_t(null_session))
            {
                
            *this = copy;
            }

            void CPPX_SessionIO::operator=const CPPX_SessionIO &copy )
            {
                pimpl_
            ->session_ptr = copy.pimpl_->session_ptr;
            }

            bool CPPX_SessionIO::operator==const CPPX_SessionIO &copy ) const
            {
                
            return m_session_id == copy.m_session_id;
            }

            long CPPX_SessionIO::getid( void )
            {
                
            return m_session_id;
            }

            bool CPPX_SessionIO::valid( void )
            {
                
            if( CPPX_Session::shared_ptr safePtr = pimpl_->session_ptr.lock() )
                    
            return true;
                
            return false;
            }

            void CPPX_SessionIO::close( void )
            {
                
            if( CPPX_Session::shared_ptr safePtr = pimpl_->session_ptr.lock() ) 
                    safePtr
            ->close();
            }

            void CPPX_SessionIO::send( const char *buffer,int length )
            {
                
            if( CPPX_Session::shared_ptr safePtr = pimpl_->session_ptr.lock() )
                    safePtr
            ->send(buffer,length);
            }

            void CPPX_SessionIO::send( const char *message )
            {
                send(message,strlen(message)
            +1);
            }

            void CPPX_SessionIO::send( const string &message )
            {
                send(message.c_str(),message.length());
            }

            string CPPX_SessionIO::expect( string service,string request )
            {
                
            // TODO : 異步請(qǐng)求響應(yīng)等待
                return "";
            }

            posted on 2009-07-22 13:16 風(fēng)雷九州 閱讀(2941) 評(píng)論(5)  編輯 收藏 引用

            FeedBack:
            # re: C++實(shí)現(xiàn)遠(yuǎn)程服務(wù)對(duì)象調(diào)用 2009-07-22 13:50 vczh
            那還是要自己寫的啊。  回復(fù)  更多評(píng)論
              
            # re: C++實(shí)現(xiàn)遠(yuǎn)程服務(wù)對(duì)象調(diào)用 2009-07-23 11:29 funix
            @vczh

            按照CORBA的結(jié)構(gòu),這部分因該算是客戶端的“樁”,還有服務(wù)端的“框架”,這些都應(yīng)該是系統(tǒng)自動(dòng)生成的代碼,只要編寫一個(gè)類似的“接口定義”文件即可,目前我也在研究中,我并不是想再造一個(gè)CORBA,只是為了學(xué)習(xí)服務(wù)器開發(fā)的這種模式。  回復(fù)  更多評(píng)論
              
            # re: C++實(shí)現(xiàn)遠(yuǎn)程服務(wù)對(duì)象調(diào)用 2009-07-25 12:09 nctt
            糟糕的設(shè)計(jì),服務(wù)特性不一,很難有效地管理,分布應(yīng)用更麻煩。
            建議每個(gè)處理單元只處理單獨(dú)幾個(gè)特性近似的服務(wù)。每個(gè)session分配一個(gè)輕量級(jí)進(jìn)程,基于消息通信。處理單元之間的通信以及與網(wǎng)絡(luò)的通信可通過(guò)高性能的FPGA實(shí)現(xiàn),F(xiàn)PGA同時(shí)負(fù)責(zé)打包解包,任務(wù)分發(fā)。  回復(fù)  更多評(píng)論
              
            # re: C++實(shí)現(xiàn)遠(yuǎn)程服務(wù)對(duì)象調(diào)用[未登錄](méi) 2009-07-30 20:22 欲三更
            這個(gè)看起來(lái)是客戶端用的dll的一部分吧?

            從代碼沒(méi)看出來(lái)“遠(yuǎn)程對(duì)象調(diào)用”這個(gè)主題啊,感覺(jué)就是把client和server之間的通信協(xié)議封裝起來(lái)了,client看到的是一個(gè)接口,或者說(shuō)proxy類,調(diào)用它的方法,它就按照一定的通信規(guī)約把命令傳給server,再接收server傳過(guò)來(lái)的結(jié)果,是這個(gè)意思吧?  回復(fù)  更多評(píng)論
              
            # re: C++實(shí)現(xiàn)遠(yuǎn)程服務(wù)對(duì)象調(diào)用 2009-08-01 21:53 風(fēng)雷九州
            @nctt

            不知所云  回復(fù)  更多評(píng)論
              

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


            久久99精品久久久久久动态图| 99久久精品国产一区二区三区 | 久久精品中文字幕第23页| 亚洲另类欧美综合久久图片区| 国产精品美女久久久久| 囯产极品美女高潮无套久久久 | 久久丫忘忧草产品| 亚洲午夜精品久久久久久浪潮| 国产精品99久久久久久猫咪| 青草影院天堂男人久久| 精品精品国产自在久久高清| 国产国产成人久久精品| 久久精品夜色噜噜亚洲A∨| 日韩十八禁一区二区久久| 中文字幕精品久久| 久久精品国产网红主播| 久久久久久a亚洲欧洲aⅴ| 国产成人无码精品久久久久免费| 久久久国产一区二区三区| 伊人久久成人成综合网222| 久久99久久99精品免视看动漫| 97久久婷婷五月综合色d啪蜜芽 | 国产精品gz久久久| 性高湖久久久久久久久AAAAA | 国产三级久久久精品麻豆三级| 精品九九久久国内精品| 欧美与黑人午夜性猛交久久久| 91精品国产91久久久久久| 日韩精品无码久久一区二区三| 久久精品国产久精国产果冻传媒| 国内精品久久久久久久97牛牛| 国产精品成人无码久久久久久| 欧美精品一区二区久久| 色婷婷综合久久久久中文一区二区| 国产精品久久久久久久久| 久久综合五月丁香久久激情| 性做久久久久久久| 亚洲国产成人久久一区久久 | 亚洲国产综合久久天堂 | 久久99国产综合精品| 国产精品青草久久久久福利99|