C++ boost::asio編程-異步TCP詳解及實例代碼
C++ boost::asio編程-異步TCP
大家好,我是異步方式
和同步方式不同,我從來不花時間去等那些龜速的IO操作,我只是向系統(tǒng)說一聲要做什么,然后就可以做其它事去了。如果系統(tǒng)完成了操作, 系統(tǒng)就會通過我之前給它的回調(diào)對象來通知我。
在ASIO庫中,異步方式的函數(shù)或方法名稱前面都有“async_ ” 前綴,函數(shù)參數(shù)里會要求放一個回調(diào)函數(shù)(或仿函數(shù))。異步操作執(zhí)行 后不管有沒有完成都會立即返回,這時可以做一些其它事,直到回調(diào)函數(shù)(或仿函數(shù))被調(diào)用,說明異步操作已經(jīng)完成。
在ASIO中很多回調(diào)函數(shù)都只接受一個boost::system::error_code參數(shù),在實際使用時肯定是不夠的,所以一般 使用仿函數(shù)攜帶一堆相關(guān)數(shù)據(jù)作為回調(diào),或者使用boost::bind來綁定一堆數(shù)據(jù)。
另外要注意的是,只有io_service類的run()方法運行之后回調(diào)對象才會被調(diào)用,否則即使系統(tǒng)已經(jīng)完成了異步操作也不會有任 務動作。
好了,就介紹到這里,下面是我?guī)淼漠惒椒绞絋CP Helloworld服務器端:
// BoostTcpServer.cpp : 定義控制臺應用程序的入口點。 // #include "stdafx.h" #include "boost/asio.hpp" #include "boost/shared_ptr.hpp" #include "boost/thread.hpp" using namespace std; using namespace boost::asio; #ifdef _MSC_VER #define _WIN32_WINNT 0X0501 //避免VC下編譯警告 #endif #define PORT 1000 #define IPV6 //#define IPV4 class AsyncServer { public: //構(gòu)造函數(shù) AsyncServer(io_service &io,ip::tcp::endpoint &ep):ios(io),acceptor(io,ep) { //acceptor(ios,ep); start(); } //啟動異步接受客戶端連接 void start() { sock_ptr sock(new ip::tcp::socket(ios)); //當有連接進入時回調(diào)accept_handler函數(shù) acceptor.async_accept(*sock, boost::bind(&AsyncServer::accept_handler,this,placeholders::error,sock)); } private: io_service &ios; ip::tcp::acceptor acceptor; typedef boost::shared_ptr<ip::tcp::socket> sock_ptr; void accept_handler(const boost::system::error_code &ec, sock_ptr sock) { if(ec) return; //輸出客戶端連接信息 std::cout <<"remote ip:"<<sock->remote_endpoint().address()<<endl; std::cout <<"remote port:"<<sock->remote_endpoint().port() << std::endl; //異步向客戶端發(fā)送數(shù)據(jù),發(fā)送完成時調(diào)用write_handler sock->async_write_some(buffer("I heard you!"), bind(&AsyncServer::write_handler,this,placeholders::error)); //再次啟動異步接受連接 start(); } void write_handler(const boost::system::error_code&) { cout<<"send msg complete!"<<endl; } }; int _tmain(int argc, _TCHAR* argv[]) { try { //定義io_service對象 io_service ios; //定義服務端endpoint對象(協(xié)議和監(jiān)聽端口) #ifdef IPV4 ip::tcp::endpoint serverep(ip::tcp::v4(),PORT); #endif #ifdef IPV6 ip::tcp::endpoint serverep(ip::tcp::v6(),PORT); #endif //啟動異步服務 AsyncServer server(ios, serverep); //等待異步完成 ios.run(); } catch (std::exception& e) { cout<<e.what()<<endl; } return 0; }
客戶端一般無需采用異步方式,同同步方式即可。
感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
相關(guān)文章
C語言實現(xiàn)將double/float 轉(zhuǎn)為字符串(帶自定義精度)
這篇文章主要介紹了C語言實現(xiàn)將double/float 轉(zhuǎn)為字符串(帶自定義精度),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-12-12C++中STL的優(yōu)先隊列priority_queue詳解
這篇文章主要介紹了C++中STL的優(yōu)先隊列priority_queue詳解,今天講一講優(yōu)先隊列(priority_queue),實際上,它的本質(zhì)就是一個heap,我從STL中扒出了它的實現(xiàn)代碼,需要的朋友可以參考下2023-08-08C語言字符串函數(shù)與內(nèi)存函數(shù)精講
這篇文章主要介紹一些c語言中常用字符串函數(shù)和內(nèi)存函數(shù)的使用,并且為了幫助讀者理解和使用,也都模擬實現(xiàn)了他們的代碼,需要的朋友可以參考一下2022-04-04C++ Template 基礎篇(一):函數(shù)模板詳解
這篇文章主要介紹了C++ Template函數(shù)模板,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2019-04-04使用VScode搭建ROS開發(fā)環(huán)境的教程詳解
這篇文章主要介紹了使用VScode搭建ROS開發(fā)環(huán)境,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-08-08