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


            精品国产91久久久久久久a| 99精品国产免费久久久久久下载 | 久久免费视频网站| 少妇内射兰兰久久| 久久天堂AV综合合色蜜桃网| 99精品久久精品一区二区| 99久久精品国产一区二区| 中文字幕无码精品亚洲资源网久久 | 久久九色综合九色99伊人| 狠狠色伊人久久精品综合网| 91精品国产91久久| 久久精品国产亚洲Aⅴ香蕉| 欧美性大战久久久久久| 中文字幕精品久久| 久久精品国产亚洲AV高清热| 国产99精品久久| 欧美亚洲另类久久综合婷婷| 亚洲国产成人精品女人久久久| 亚洲精品97久久中文字幕无码| 一本色道久久综合| 国产精品禁18久久久夂久 | 一个色综合久久| 久久夜色精品国产噜噜亚洲AV| 国产精品九九九久久九九 | 久久久久国产一级毛片高清板| 欧美一级久久久久久久大片 | 久久综合久久美利坚合众国| 日韩精品久久无码中文字幕| 婷婷久久综合九色综合98| 午夜精品久久久久久| 久久久亚洲欧洲日产国码二区| 国产日韩欧美久久| 人妻无码中文久久久久专区| 精品久久人人做人人爽综合 | 中文字幕久久亚洲一区| 97久久香蕉国产线看观看| 人妻无码久久精品| 久久美女网站免费| 一本色综合网久久| 久久中文字幕无码专区| 久久99热国产这有精品|