繁体   English   中英

子类化 std::chrono::duration

[英]Subclassing std::chrono::duration

我有一段代码,其中std::chrono::duration<int64_t, std::milli>是子类,并用于创建std::chrono::time_point ,如下所示:

#include <chrono>

class my_duration : public std::chrono::duration<int64_t, std::milli>
{ /* snip */ };

int main() 
{
    typedef std::chrono::time_point< std::chrono::system_clock, my_duration > my_time_point;
    my_time_point t( my_duration{} );
    //....
}

当使用 GCC < 10 时,这似乎编译和工作正常。但是,当使用 GCC 10 时,staticchrono 断言将失败:

/opt/wandbox/gcc-head/include/c++/11.0.0/chrono:764:37:错误:static 断言失败:duration 必须是 std::chrono::duration 的特化

这可以在以下链接中看到,这也表明 clang 给出了相同的错误: https://wandbox.org/permlink/CQw6fWt4kZ1xYdet

在 std::chrono 中,失败的断言是由于__is_duration使用的time_point结构:

template<typename _Tp>
  struct __is_duration
  : std::false_type
  { };

template<typename _Rep, typename _Period>
  struct __is_duration<duration<_Rep, _Period>>
  : std::true_type
  { };

//... further down, in time_point: 
static_assert(__is_duration<_Dur>::value,
    "duration must be a specialization of std::chrono::duration");

我的理解是__is_duration<my_duration>将是一个std::false_type导致 static 断言失败。

所以,我的问题是:这是否意味着不可能继承 std::chrono::duration 并将派生的 class 与 time_point 一起使用? 或者是否有一些技巧可以让持续时间子类通过 static 断言?

std::time_point始终要求持续时间类型是std::duration的特化。 如果不是,则程序格式错误(又名:编译错误)。 这可能只是 GCC 第一次实现该要求。

duration派生并没有真正起到任何有用的目的。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM