从另一个线程以原子方式取消asio异步计时器

时间:2015-03-14 10:16:43

标签: multithreading boost timer cancellation

我有一个boost deadline_timer,它定期运行(如例http://www.boost.org/doc/libs/1_35_0/doc/html/boost_asio/tutorial/tuttimer3/src.html中所示):

#include <iostream>
#include <boost/asio.hpp>
#include <boost/bind.hpp>
#include <boost/date_time/posix_time/posix_time.hpp>

void print(const boost::system::error_code& /*e*/,
    boost::asio::deadline_timer* t)
{
    t->expires_at(t->expires_at() + boost::posix_time::seconds(1));
    t->async_wait(boost::bind(print,
          boost::asio::placeholders::error, t, count));
}

int main()
{
  boost::asio::io_service io;

  boost::asio::deadline_timer t(io, boost::posix_time::seconds(1));
  t.async_wait(boost::bind(print,
        boost::asio::placeholders::error, &t));

  io.run();

  return 0;
}

现在我需要从另一个线程取消它。 但是如果取消的调用仅在打印功能执行期间但在expires_at调用之前出现怎么办?然后计时器将继续运行。

处理它的一种方法是运行类似

的东西
while (timer.cancel() == 0) {
}

在单独的线程函数中。

但也许有人知道这个问题可以做得更优雅吗?

0 个答案:

没有答案