以线程安全的方式快速将 double 转换为 uint64_t

fast convert double to uint64_t in thread safe way

我在并行循环中调用了以下函数。为了线程安全,我在下面的函数中声明了 union 。问题是这样做很慢。我的问题是是否有一种方法可以将 double 变成 uin64_t(与 union 的方法相同)但速度更快?谢谢。

uint64_t flip(double d) {
  union {double d; uint64_t u64;} u;
  u.d = d;
  return u.u64 ^ (-(u.u64 >> 63) | 0x8000000000000000ULL);
}

我正在使用 gcc 编译代码。

您可以尝试将此作为宏重新执行以消除函数的 callreturn 开销:

#define DOUBLE_TO_UINT64(d) ((*(uint64_t *)(&(d))) ^ (-( (*(uint64_t *)(&(d))) >> 63) | 0x8000000000000000ULL))