boost::asio小记

同步通讯的流程同步通讯的过程

io对象

I/O对象(通常需要使用io_service构造)
例如一个TCP套接字

boost::asio::ip::tcp::socket socket(io_service);
socket.connect(endpoint, error_code);
socket.read_some(asio::buffer,error_code);

boost::asio::io_service

程序中需要至少定义一个io_service对象
io_service表示程序到操作系统I/O服务的“连接”。
io_service对象是asio框架中的调度器,所有异步io事件都是通过它来分发处理的(io对象的构造函数中都需要传入一个io_service对象)。io_servie 实现了一个任务队列,io_servie最常用的两个接口是post和run,post向任务队列中投递任务,run是执行队列中的任务,直到全部执行完毕,并且run可以被N个线程调用。Io_service是完全线程安全的队列。

asio::io_service io_service;
asio::ip::tcp::socket socket(io_service);

boost::asio::io_service::work

防止io_service.run()结束后线程退出
boost::asio::io_service io;
boost::asio::io_service::work work(io);
io.run();

work是一个很小的辅助类,只支持构造函数和析构函数。 构造一个work时,outstanding_work_+1,使得io.run在完成所有异步消息后判断outstanding_work_时不会为0,因此会继续调用GetQueuedCompletionStatus并阻塞在这个函数上。
而析构函数中将其-1,并判断其是否为0,如果是,则post退出消息给GetQueuedCompletionStatus让其退出。特别注意的是,work提供了一个拷贝构造函数,因此可以直接在任意地方使用。对于一个io_service来说,有多少个work实例关 联,则outstanding_work_就+1了多少次,只有关联到同一个io_service的work全被析构之后,io.run才会在所有消息处 理结束之后正常退出。

Guess you like

Origin blog.csdn.net/weixin_53022668/article/details/121208902