我链接read_async_some()
调用以从串行端口异步读取。在某些时候,我需要使用取消异步读取,并在关联的处理程序中检测到这一事实。从the documentation for cancel()
,我希望可以通过检查传递给我的处理程序的error_code
来做到这一点:
但是,当我尝试这样做时,我的处理程序将被调用invalid_argument
错误而不是预期的operation_aborted
错误。这是一个最小的示例,该示例通过使用ptty模拟串行端口来重现该问题:
void handle(boost::system::error_code const& error, size_t count)
{
std::cout << "error_code = " << error.message() << std::endl;
}
int main(int argc, char **argv)
{
std::fstream fs("/dev/ttyp0", std::ios::in | std::ios::ate);
boost::asio::io_service io;
boost::asio::serial_port serial(io, "/dev/ttyp0");
std::vector<uint8_t> buffer(1);
serial.async_read_some(boost::asio::buffer(buffer),
boost::bind(&handle,
boost::asio::placeholders::error,
boost::asio::placeholders::bytes_transferred
)
);
boost::thread thread(boost::bind(&boost::asio::io_service::run, &io));
serial.cancel();
thread.join();
fs.close();
}
至少对我来说,该程序的输出是
error_code = Invalid argument
。谁能解释为什么我没有得到文档中描述的行为? 最佳答案
没关系。如果其他任何人遇到相同的问题,则问题实际上是使用pttys进行测试。事实证明,ptty在用于异步输入时不能正常工作,并且boost::asio
表示上述错误消息存在此问题。
我可以通过使用socat
创建一个模拟的回送串行端口来解决此问题。 this blog post中提供了很好的说明。