我有一个使用asio截止时间计时器的应用程序。应用程序的其余部分使用std::chrono
构造作为其时间值,并且仅将boost::posix_time
用于触及asio的内容感觉很尴尬。如果可以的话,我想在整个应用程序中使用std::chrono
,以保持一致性,可读性等。
在我看来,答案将涉及使用计时器的模板:
typedef boost::asio::basic_deadline_timer<std::chrono::system_clock::time_point>
my_deadline_timer_type;
my_deadline_timer_type a_timer(io_service);
除了在编译时严重爆炸......多行错误,其中大部分与此类似:
/opt/arm/include/boost/asio/deadline_timer_service.hpp:51:43:错误:无效使用不完整类型'boost :: asio :: deadline_timer_service&gt; &gt;,boost :: asio :: time_traits&gt; &GT; &GT; &gt; :: traits_type {aka struct boost :: asio :: time_traits&gt; &GT; &GT;}'
所以,看起来我可能需要创建一个新的traits_type
并使用它来声明deadline_timer_service
,但我不确定如何/在哪里。我不得不相信这个问题已经解决了。我在linux上使用g ++ 4.7.3和-std = c ++ 11,交叉编译到arm。
答案 0 :(得分:25)
如果您使用的是boost 1.49或更高版本,ASIO会引入basic_waitable_timer,它使用来自std::chrono
或boost::chrono
的C ++ 11兼容时钟。他们还为steady_clock
,system_clock
和high_resolution_clock
的提升版本提供了预定义的typedef。它的功能与deadline_timer
相同,但使用C ++ 11时钟机制而不是boost::posix_time
结构。
对于早期版本,您将不得不传递特征结构来处理转换为deadline_timer
所期望的类型。请参阅ASIO TimeTraits要求。大多数都是微不足道的,最后一个不是。所以,例如
template<typename Clock>
struct CXX11Traits
{
typedef typename Clock::time_point time_type;
typedef typename Clock::duration duration_type;
static time_type now()
{
return Clock::now();
}
static time_type add(time_type t, duration_type d)
{
return t + d;
}
static duration subtract(time_type t1, time_type t2)
{
return t1-t2;
}
static bool less_than(time_type t1, time_type t2)
{
return t1 < t2;
}
static boost::posix_time::time_duration
to_posix_duration(duration_type d1)
{
using std::chrono::duration_cast;
auto in_sec = duration_cast<std::chrono::seconds>(d1);
auto in_usec = duration_cast<std::chrono::microseconds>(d1 - in_sec);
boost::posix_time::time_duration result =
boost::posix_time::seconds(in_sec.count()) +
boost::posix_time::microseconds(in_usec.count());
return result;
}
};
然后,您将为要使用的每个C ++ 11时钟创建截止时间计时器。这里的示例适用于std::system_clock
。您可以正常使用此截止日期计时器。
typedef boost::asio::basic_deadline_timer<
std::system_clock,
CXX11Traits<std::system_clock>> my_system_clock_deadline_timer