boost asio 中的并发读取和 async_read_some
Concurrent read and async_read_some in boost asio
假设在boost::asio中的套接字上启用了async_read_some服务,如果在同一套接字上调用阻塞读取会发生什么情况?
一段伪代码如下:
using boost::asio::local::stream_protocol;
boost::asio::io_service io;
stream_protocol::socket s(io);
s.connect(stream_protocol::endpoint(address));
s.async_read_some(aBuffer, aCallback); // start async_read
boost::thread thread(boost::bind(&boost::asio::io_service::run, &io));
usleep(1000000); // do some stuff
boost::asio::read(bBuffer); // request a blocking read
我的天真测试表明,阻塞读取总是优先:数据将在调用异步回调之前首先填充 bBuffer。这是我想要的行为。
问题:
这是有保证的行为吗?在所有套接字类型上?
Boost.Asio 不对任何 I/O 对象做出此保证。当对具有相同类型的未完成异步操作的 I/O 对象启动同步操作时,未指定底层系统调用发生的顺序。
假设在boost::asio中的套接字上启用了async_read_some服务,如果在同一套接字上调用阻塞读取会发生什么情况?
一段伪代码如下:
using boost::asio::local::stream_protocol;
boost::asio::io_service io;
stream_protocol::socket s(io);
s.connect(stream_protocol::endpoint(address));
s.async_read_some(aBuffer, aCallback); // start async_read
boost::thread thread(boost::bind(&boost::asio::io_service::run, &io));
usleep(1000000); // do some stuff
boost::asio::read(bBuffer); // request a blocking read
我的天真测试表明,阻塞读取总是优先:数据将在调用异步回调之前首先填充 bBuffer。这是我想要的行为。
问题: 这是有保证的行为吗?在所有套接字类型上?
Boost.Asio 不对任何 I/O 对象做出此保证。当对具有相同类型的未完成异步操作的 I/O 对象启动同步操作时,未指定底层系统调用发生的顺序。