我的应用程序(C++、Windows)正在与外部设备通信。如果设备在一段时间后没有应答,我想重置一个状态变量。
我最初的做法是
auto timer = boost::asio::deadline_timer(io_svc);
timer.expires_from_now(boost::posix_time::seconds(10));
timer.async_wait(boost::bind(&Class::CurrRequestTimeout, this, boost::asio::placeholders::error));
io_svc.poll();
和超时函数
void Class::CurrRequestTimeout(const boost::system::error_code & ec)
{
if (ec)
{
// this timeout was canceled
return;
}
ResetStatusVariable();
}
这应该是非阻塞的,这就是我选择 poll() 而不是 run() 的原因(参见 here )。但是,使用 poll() 永远不会调用超时方法。使用 run() 它工作得很好,但这会阻止执行。
最佳答案
poll
函数只运行准备好在那一刻运行的处理程序。由于计时器尚未超时,因此它现在无法运行该处理程序。你要求它不要阻止。那么您希望它做什么?
如果您的代码是线程安全的,请创建另一个可以在run
中阻塞的线程。如果没有,则此线程必须返回并稍后调用 poll
以使处理程序有机会运行。
一个警告:如果您确实创建了一个或多个run
线程,您需要确保始终至少有一个事件要等待,否则线程将无法等待处理程序。 boost::asio::io_service::work
就是为了这个目的。参见 this question .
关于c++ - 使用 C++ 在超时后重置变量,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13562588/