• <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>
            隨筆-379  評論-37  文章-0  trackbacks-0
            ASIO的同步方式
             Boost.Asio是一個跨平臺的網絡及底層IO的C++編程庫,它使用現代C++手法實現了統一的異步調用模型。
            頭文件 #include
            名空間 using namespace boost::asio;
            ASIO庫能夠使用TCP、UDP、ICMP、串口來發送/接收數據,
            下面先介紹TCP協議的讀寫操作對于讀寫方式,ASIO支持同步和異步兩種方式,
            首先登場的是同步方式,
            下面請同步方式自我介紹一下:大家好!我是同步方式!我的主要特點就是執著!
            所有的操作都要完成或出錯才會返回,不過偶的執著被大家稱之為阻塞,實在是郁悶~~(場下一片噓聲),
            其實這樣 也是有好處的,比如邏輯清晰,編程比較容易。
            在服務器端,我會做個socket交給acceptor對象,讓它一直等客戶端連進來,連上以后再通過這個socket與客戶端通信,
            而所有的通信都是以阻塞方式進行的,讀完或寫完才會返回。在客戶端也一樣,
            這時我會拿著socket去連接服務器,當然也是連上或出錯了才返回,最后也是以阻塞的方式和服務器通信。
            有人認為同步方式沒有異步方式高效,其實這是片面的理解。
            在單線程的情況下可能確實如此,我不能利用耗時的網絡操作這段時間做別的事 情,不是好的統籌方法。
            不過這個問題可以通過多線程來避免,比如在服務器端讓其中一個線程負責等待客戶端連接,連接進來后把socket交給另外的線程去 和客戶端通信,這樣與一個客戶端通信的同時也能接受其它客戶端的連接,主線程也完全被解放了出來。
            我的介紹就有這里,謝謝大家!好,感謝同步方式的自我介紹,
            現在放出同步方式的演示代碼(起立鼓掌!):
            服務器端
            1.#include
            2.#include
            3.
            4.using namespace boost::asio;
             5.
             6.int main(int argc, char* argv[])
            7.{
            8. // 所有asio類都需要io_service對象
            9. io_service iosev;
            10. ip::tcp::acceptor acceptor(iosev,
            11. ip::tcp::endpoint(ip::tcp::v4(), 1000));
            12. for(;;)
            13. {
            14. // socket對象
            15. ip::tcp::socket socket(iosev);
             16. // 等待直到客戶端連接進來
            17. acceptor.accept(socket);
            18. // 顯示連接進來的客戶端
            19. std::cout << socket.remote_endpoint().address() << std::endl;
            20. // 向客戶端發送hello world!
            21. boost::system::error_code ec;
            22. socket.write_some(buffer("hello world!"), ec);
            23.
            24. // 如果出錯,打印出錯信息
            25. if(ec)
            26. {
            27. std::cout <<
            28. boost::system::system_error(ec).what() << std::endl;
            29. break;
            30. }
            31. // 與當前客戶交互完成后循環繼續等待下一客戶連接
            32. }
            33. return 0;
            34.}

            客戶端
            1.#include
            2.#include
            3.
            4.using namespace boost::asio;
            5.
            6.int main(int argc, char* argv[])
            7.{
            8. // 所有asio類都需要io_service對象
            9. io_service iosev;
            10. // socket對象
            11. ip::tcp::socket socket(iosev);
            12. // 連接端點,這里使用了本機連接,可以修改IP地址測試遠程連接
            13. ip::tcp::endpoint ep(ip::address_v4::from_string("127.0.0.1"), 1000);
            14. // 連接服務器
            15. boost::system::error_code ec;
            16. socket.connect(ep,ec);
            17. // 如果出錯,打印出錯信息
            18. if(ec)
            19. {
            20. std::cout << boost::system::system_error(ec).what() << std::endl;
            21. return -1; 22. }
            23. // 接收數據
            24. char buf[100];
            25. size_t len=socket.read_some(buffer(buf), ec);
            26. std::cout.write(buf, len);
            27.
            28. return 0;
            29.}

            從演示代碼可以得知
            •ASIO的TCP協議通過boost::asio::ip名 空間下的tcp類進行通信。
            •IP地址(address,address_v4,address_v6)、 端口號和協議版本組成一個端點(tcp:: endpoint)。
            用于在服務器端生成tcp::acceptor對 象,并在指定端口上等待連接;或者在客戶端連接到指定地址的服務器上。
            •socket是 服務器與客戶端通信的橋梁,連接成功后所有的讀寫都是通過socket對 象實現的,當socket析 構后,連接自動斷 開。
            •ASIO讀寫所用的緩沖區用buffer函 數生成,這個函數生成的是一個ASIO內部使用的緩沖區類,它能把數組、指針(同時指定大 小)、std::vector、std::string、boost::array包裝成緩沖區類。
             •ASIO中的函數、類方法都接受一個boost::system::error_code類 型的數據,用于提供出錯碼。
            它可以轉換成bool測試是否出錯,并通過boost::system::system_error類 獲得詳細的出錯信息。
            另外,也可以不向ASIO的函數或方法提供 boost::system::error_code,這時如果出錯的話就會直 接拋出異常,異常類型就是boost::system:: system_error(它是從std::runtime_error繼承的)。
            posted on 2009-08-19 00:29 小王 閱讀(651) 評論(0)  編輯 收藏 引用 所屬分類: 網絡通訊
            久久久女人与动物群交毛片| 精品久久久久久无码专区 | 成人亚洲欧美久久久久| 日本免费一区二区久久人人澡 | 久久久精品国产| AV无码久久久久不卡蜜桃| 久久久久久毛片免费播放| 国产一区二区三区久久精品| 久久综合伊人77777麻豆| 亚洲熟妇无码另类久久久| 久久精品一区二区国产| 精品久久久久久无码中文野结衣 | 漂亮人妻被中出中文字幕久久| 久久精品国产亚洲av影院| 久久精品国产亚洲AV不卡| 亚洲AV无码久久精品蜜桃| 国产AⅤ精品一区二区三区久久| 久久精品成人欧美大片| 99久久精品毛片免费播放| 久久久精品人妻无码专区不卡 | 久久中文字幕视频、最近更新| 国产成年无码久久久免费| 狠狠综合久久综合中文88| 国产精品久久久久久影院| 一本久久精品一区二区| 久久久久久久久久久免费精品| 国产V综合V亚洲欧美久久| 精品久久久无码21p发布| 亚洲国产精品成人久久蜜臀| 色综合久久久久网| 丁香狠狠色婷婷久久综合| 亚洲AV无码成人网站久久精品大| 久久露脸国产精品| 91精品日韩人妻无码久久不卡| 男女久久久国产一区二区三区| 欧美亚洲国产精品久久高清 | 色综合久久久久网| 国产99久久久国产精免费| 久久综合九色综合久99| 中文字幕亚洲综合久久2| 国产精品久久久久一区二区三区|