我链接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中提供了很好的说明。

09-28 05:07