我正在寻找一个更好的例子boost::asio::deadline_timer
给出的示例总是会超时并调用该close
方法。我尝试调用cancel()
一个计时器,但这会导致传入的函数async_wait
立即被调用。
在异步 tcp 客户端中使用计时器的正确方法是什么?
我正在寻找一个更好的例子boost::asio::deadline_timer
给出的示例总是会超时并调用该close
方法。我尝试调用cancel()
一个计时器,但这会导致传入的函数async_wait
立即被调用。
在异步 tcp 客户端中使用计时器的正确方法是什么?
您提到在计时器上调用 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;
}
}
希望这会有所帮助。如果不是,您要查找的具体示例是什么?