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

            專職C++

            不能停止的腳步

              C++博客 :: 首頁 :: 聯系 :: 聚合  :: 管理
              163 Posts :: 7 Stories :: 135 Comments :: 0 Trackbacks

            常用鏈接

            留言簿(28)

            我參與的團隊

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

            一個基于ASIO異步讀寫的客戶端類實現,使用了類委托方法。使它可以不使用派生就可以獲得數據發送接收的控制。這個使用了boost和我的tinyC++庫(http://www.shnenglu.com/zdhsoft/archive/2010/09/08/126172.html)。這個例子,希望可以給大家做為學習ASIO的異??蛻舳死?。
            具體實現如下:

              1 #ifndef _X_ASIO_CLIENT_H_
              2 #define _X_ASIO_CLIENT_H_
              3 #include "xasio_head.h"
              4 #include "xdelegate.h"
              5 #include "xbuffer.h"
              6 #include "xdatetime.h"
              7 template<int NSIZE = 128>
              8 class XASIOClient
              9 {
             10 public:
             11     XASIOClient(boost::asio::io_service & paramIOService)
             12         :m_Socket(paramIOService),
             13          m_WaitTime(paramIOService),
             14          m_Connected(false),
             15          m_WaitTimeCancelFlag(false),
             16          m_LastReadTime(0)
             17     {
             18     }
             19 
             20     ~XASIOClient()
             21     {
             22 
             23     }
             24 
             25     bool Connect(const char * paramServerIP, unsigned short int paramServerPort, int paramTimeout = 5000)
             26     {
             27         if( isConnected() ) return false;
             28 
             29         m_Socket.get_io_service().reset();
             30         m_ErrorCode.assign(0,boost::system::get_system_category());
             31         m_WaitTimeCancelFlag = false;
             32         boost::asio::ip::tcp::endpoint epServer(boost::asio::ip::address_v4::from_string(paramServerIP), paramServerPort);
             33         m_WaitTime.expires_from_now( boost::posix_time::milliseconds(paramTimeout));
             34         m_Socket.async_connect(epServer, boost::bind(&XASIOClient::DoConnectEvent,this,_1,epServer));
             35         m_WaitTime.async_wait(boost::bind(&XASIOClient::DoConnectedTimeOutEvent,this));
             36         m_Socket.get_io_service().run();
             37         return isConnected();
             38 
             39     }
             40     bool isConnected() const
             41     {
             42         return m_Connected;
             43     }
             44     const boost::system::error_code & getErrorCode() const
             45     {
             46         return m_ErrorCode;
             47     }
             48     boost::asio::ip::tcp::socket & getSocket() 
             49     {
             50         return m_Socket;
             51     }
             52     void StartRead(int paramTimeout = 3000)
             53     {
             54         if!isConnected() ) return;
             55         m_Socket.get_io_service().reset();
             56         EventOnReadBefore.Invoke(m_Socket);
             57         m_LastReadTime = zdh::GetNowDateTime(); //設置超時時間
             58         m_Socket.async_read_some(boost::asio::buffer(m_ReadBuffer),boost::bind(&XASIOClient::DoReadEvent,this,_1,_2, paramTimeout));
             59         m_Socket.get_io_service().run();
             60         EventOnReadAfter.Invoke(m_Socket);
             61     }    
             62     void StartWrite(void * paramSendData, int paramSendDataBytes, int paramTimeout = 3000)
             63     {
             64         if!isConnected() ) return;
             65         EventOnWriteBefore.Invoke(m_Socket);
             66         m_Socket.get_io_service().reset();
             67         m_WaitTimeCancelFlag = false;
             68         m_WaitTime.expires_from_now(boost::posix_time::milliseconds(paramTimeout));
             69         m_Socket.async_write_some(boost::asio::buffer(paramSendData,paramSendDataBytes), boost::bind(&XASIOClient::DoWriteEvent,this,_1,_2,paramSendData,paramSendDataBytes,paramTimeout));
             70         m_WaitTime.async_wait(boost::bind(&XASIOClient::DoWriteTimeOutEvent,this));
             71         m_Socket.get_io_service().run();
             72         EventOnWriteAfter.Invoke(m_Socket);
             73     }
             74 private:
             75     void DoWriteTimeOutEvent()
             76     {
             77         if!m_WaitTimeCancelFlag ) //如沒有被取消,則執行Timeout事件
             78         {
             79             EventOnWriteTimeout.Invoke(m_Socket);
             80         }
             81     }
             82     void DoWriteEvent(const boost::system::error_code & paramErrorCode, std::size_t paramBytesTransferred,void * paramSendData, int paramSendDataBytes, int paramTimeout )
             83     {
             84         m_WaitTime.expires_from_now(boost::posix_time::milliseconds(paramTimeout));
             85         m_WaitTime.async_wait(DoWriteTimeOutEvent);
             86     
             87         if!paramTimeout)
             88         {
             89             m_ErrorCode = paramErrorCode;
             90             EventOnWriteError.Invoke( m_Socket, paramErrorCode );
             91             return;
             92         }
             93         if( paramBytesTransferred > 0)
             94         {
             95             EventOnWrite.Invoke(m_Socket, (int)paramBytesTransferred, paramSendData, paramSendDataBytes );
             96         }
             97     }
             98     void DoReadEvent(const boost::system::error_code & paramErrorCode,std::size_t paramBytes_Transfered,int paramTimeout)
             99     {
            100         
            101         bool bContinue = true;
            102         if( paramBytes_Transfered > 0 ) //如果有接收到數據
            103         {
            104             m_LastReadTime = zdh::GetNowDateTime();//有數據到達,重置Timeout時間
            105             EventOnRead.Invoke(m_Socket, m_ReadBuffer, intparamBytes_Transfered, bContinue);
            106         }
            107         if( bContinue && (zdh::GetNowDateTime() - m_LastReadTime) >  paramTimeout )
            108         {
            109             //如果超時
            110             bContinue = false;
            111             EventOnReadTimeout.Invoke(m_Socket);
            112 
            113         }
            114         if( bContinue && isConnected()) 
            115         {
            116             m_Socket.async_read_some(boost::asio::buffer(m_ReadBuffer),boost::bind(&XASIOClient::DoReadEvent,this,_1,_2, paramTimeout));
            117         }
            118     }    
            119     void DoConnectedTimeOutEvent()
            120     {
            121         if!m_WaitTimeCancelFlag ) //如沒有被取消,則執行Timeout事件
            122         {
            123             EventOnConnectTimeout.Invoke(m_Socket);
            124         }
            125     }
            126 
            127     void DoConnectEvent(const boost::system::error_code & paramErrorCode, const boost::asio::ip::tcp::endpoint & paramEndPoint)
            128     {
            129         m_WaitTimeCancelFlag = true//取消timeout事件
            130         m_WaitTime.cancel();
            131 
            132         m_Connected = !paramErrorCode;
            133         m_ErrorCode = paramErrorCode;
            134         EventOnConnent.Invoke(m_Socket, paramErrorCode, paramEndPoint);
            135     }
            136 public:
            137     //連接事件
            138     //void OnConnectTimeout(boost::asio::ip::tcp::socket & paramSocket);
            139     zdh::XDelegate1<boost::asio::ip::tcp::socket &> EventOnConnectTimeout;
            140     //void OnConnect(boost::asio::ip::tcp::socket & paramSocket,const boost::system::error_code & paramErrorCode, const boost::asio::ip::tcp::endpoint & paramServerPoint);
            141     zdh::XDelegate3<boost::asio::ip::tcp::socket &,const boost::system::error_code &const boost::asio::ip::tcp::endpoint &> EventOnConnent;
            142 
            143     //讀取事件
            144     //void OnReadBefore(boost::asio::ip::tcp::socket & paramSocket);
            145     zdh::XDelegate1<boost::asio::ip::tcp::socket &> EventOnReadBefore;
            146     //void OnReadAfter(boost::asio::ip::tcp::socket & paramSocket);
            147     zdh::XDelegate1<boost::asio::ip::tcp::socket &> EventOnReadAfter;
            148     //void OnRead(boost::asio::ip::tcp::socket & paramSocket, void * paramReadData, int paramReadBytes, bool paramContinue);
            149     zdh::XDelegate4<boost::asio::ip::tcp::socket &,void *int,bool &> EventOnRead;
            150     //void OnReadTimeout(boost::asio::ip::tcp::socket & paramSocket);
            151     zdh::XDelegate1<boost::asio::ip::tcp::socket &> EventOnReadTimeout;
            152 
            153     //寫入事件
            154     //void OnWriteBefore(boost::asio::ip::tcp::socket & paramSocket);
            155     zdh::XDelegate1<boost::asio::ip::tcp::socket &> EventOnWriteBefore;
            156     //void OnWriteAfter(boost::asio::ip::tcp::socket & paramSocket);
            157     zdh::XDelegate1<boost::asio::ip::tcp::socket &> EventOnWriteAfter;
            158     //void OnWrite(boost::asio::ip::tcp::socket & paramSocket, int paramWriteBytes,void * paramWriteData, int paramWriteDataBytes);
            159     zdh::XDelegate4<boost::asio::ip::tcp::socket &,intvoid *int> EventOnWrite;
            160     //void OnWriteTimeout(boost::asio::ip::tcp::socket & paramSocket);
            161     zdh::XDelegate1<boost::asio::ip::tcp::socket &> EventOnWriteTimeout;
            162     //void OnWriteError(boost::asio::ip::tcp::socket & paramSocket, boost::asio::error_code & paramCode);
            163     zdh::XDelegate2<boost::asio::ip::tcp::socket &, boost::system::error_code &> EventOnWriteError;
            164 
            165 private:
            166     boost::asio::ip::tcp::socket m_Socket;        ///<連接句柄
            167     
            168     boost::asio::deadline_timer m_WaitTime;        ///<用于檢查超時服務器定時器
            169     bool m_WaitTimeCancelFlag;                    ///<True表示m_WaitTime產生的事件無效,false表示有效
            170 
            171     bool m_Connected;
            172     boost::system::error_code m_ErrorCode;        ///<最后出標志
            173     zdh::XLong m_LastReadTime;                    ///<最近一次讀取數據的時間
            174     
            175     zdh::XByte m_ReadBuffer[NSIZE];
            176 
            177 };
            178 #endif
            179 
            posted on 2010-11-04 15:16 冬瓜 閱讀(5066) 評論(2)  編輯 收藏 引用

            Feedback

            # re: 一個基于ASIO異步讀寫的客戶端類實現 2010-11-05 13:30
            一個簡單的通信怎么給你寫的這么......  回復  更多評論
              

            # re: 一個基于ASIO異步讀寫的客戶端類實現 2010-11-05 16:11 冬瓜
            請多指教@釀
              回復  更多評論
              

            久久精品国产久精国产一老狼| 久久精品草草草| 久久免费视频1| 2022年国产精品久久久久| 久久久久久亚洲Av无码精品专口 | 无码人妻少妇久久中文字幕| 欧美与黑人午夜性猛交久久久| 99久久无色码中文字幕人妻| 91精品国产91久久久久福利| 伊人久久大香线蕉精品不卡| 精品国产乱码久久久久久郑州公司 | 欧美黑人激情性久久| 国内精品伊人久久久久影院对白| 久久99久国产麻精品66| 99久久99久久精品国产片果冻| 精品熟女少妇AV免费久久| 久久综合九色综合精品| 亚洲中文字幕久久精品无码喷水| 国产精品美女久久久久av爽| 久久久一本精品99久久精品66| 色婷婷久久久SWAG精品| 亚洲一区二区三区日本久久九| 亚洲国产精品无码久久98| 欧美日韩中文字幕久久久不卡 | 国产农村妇女毛片精品久久| 精品久久久中文字幕人妻| 色99久久久久高潮综合影院| 国产综合成人久久大片91| 一本一道久久精品综合| 韩国三级大全久久网站| 久久精品国产亚洲AV高清热| 国色天香久久久久久久小说| 伊人久久精品影院| 一级a性色生活片久久无| 欧美粉嫩小泬久久久久久久 | 日本亚洲色大成网站WWW久久| 亚洲国产精品久久久久久| 久久国产精品久久国产精品| 香港aa三级久久三级| Xx性欧美肥妇精品久久久久久| 伊人久久免费视频|