【问题标题】:Cast chrono::milliseconds to uint64_t?将 chrono::milliseconds 转换为 uint64_t?
【发布时间】:2015-03-10 13:07:09
【问题描述】:

假设我在变量 x 中有毫秒数:

chrono::milliseconds x = std::chrono::duration_cast<chrono::milliseconds>(something);

如何将xchrono::milliseconds 转换为uint64_t

我试过了:

uint64_t num = std::chrono::duration_cast<uint64_t>(x);

但它说:

没有匹配的调用函数 duration_cast(std::chrono::milliseconds&)

【问题讨论】:

标签: c++ c++11 chrono


【解决方案1】:

首先,您通常不应该做这种事情。 &lt;chrono&gt; 提供了一个类型安全的通用单元库来处理持续时间,几乎没有什么好的理由可以逃避这种安全性和通用性。

类型安全的泛型单元库不会发生的问题以及类型不安全的整数类型会发生的问题的一些示例:

// a type-safe units library prevents these mistakes:
int seconds = ...
int microseconds = seconds * 1000; // whoops
int time = seconds + microseconds; // whoops

void bar(int seconds);

bar(microseconds); // whoops

// a generic duration type prevents the need for:
unsigned sleep(unsigned seconds);
int usleep(useconds_t useconds);
int nanosleep(const struct timespec *rqtp, struct timespec *rmtp);

int attosleep(long long attoseconds); // ???

// just use:
template<typename Duration>
int sleep_for(Duration t); // users can specify sleep in terms of hours, seconds, microseconds, femetoseconds, whatever. Actual sleep duration depends on QoI, as always.

一个很好的例子是与第三方库的兼容性,该第三方库不幸决定不在其 API 中使用类型安全的通用单元库。在这种情况下,转换应尽可能靠近 API 边界进行,以尽量减少使用不安全类型的程度。


话虽如此,当你有充分的理由时,你会这样做:

std::chrono::milliseconds x = ...
std::uint64_t num = x.count();

请记住,预定义的计时持续时间(例如 chrono::milliseconds)使用有符号表示,因此您需要注意确保该值适合转换为 uint64_t

【讨论】:

  • duration_cast 会将无符号转换处理为 uint64_t 吗?
  • @user997112 它会进行强制转换,但不会做任何特殊的事情来防止溢出错误或将负值强制转换为大的无符号值。
【解决方案2】:

std::chrono::duration_cast 的原型是:

template <class ToDuration, class Rep, class Period>
constexpr ToDuration duration_cast(const duration<Rep,Period>& d);

您无法直接获得uint64_t,因为它会转换持续时间 (duration_cast)。所以你需要用std::uint64_t创建一个std::duration

using cast = std::chrono::duration<std::uint64_t>;
std::uint64_t ticks = std::chrono::duration_cast< cast >(something).count();

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2017-06-28
    • 1970-01-01
    • 1970-01-01
    • 2021-11-19
    • 2023-04-01
    • 1970-01-01
    相关资源
    最近更新 更多