6

我正在寻找一个更好的例子boost::asio::deadline_timer

给出的示例总是会超时并调用该close方法。我尝试调用cancel()一个计时器,但这会导致传入的函数async_wait立即被调用。

在异步 tcp 客户端中使用计时器的正确方法是什么?

4

1 回答 1

20

您提到在计时器上调用 cancel() 会导致传递给 async_wait 的函数立即被调用。这是预期的行为,但请记住,您可以检查传递给计时器处理程序的错误以确定计时器是否已取消。如果定时器被取消,则传递 operation_aborted。例如:

void handleTimer(const boost::system::error_code& error) {
    if (error == boost::asio::error::operation_aborted) {
        std::cout << "Timer was canceled" << std::endl;
    }
    else if (error) {
        std::cout << "Timer error: " << error.message() << std::endl;
    }
}

希望这会有所帮助。如果不是,您要查找的具体示例是什么?

于 2009-12-19T00:43:16.447 回答