我正在寻找一个更好的 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;
}
}
希望这对您有所帮助。如果不是,您要查找的具体示例是什么?
关于c++ - 更好地提升 asio deadline_timer 示例,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1918911/