C++ 解释将 uint64 转换为 uint32

Sal*_*kes 5 c++ unsigned casting

我正在尝试将 uint64_t(使用 boost chrono 高精度时钟表示从 D 日起以纳秒为单位的时间)到 uint32_t 以生成随机数生成器。

我只想要 uint64_t 的最低有效 32 位。这是我的尝试:

uint64_t ticks64 = dtn.count(); // This has the ticks in nanosec
uint64_t ticks32_manual = ticks64 & 0xFFFFFFFF;
uint32_t ticks32_auto = (uint32_t) ticks64;
mexPrintf("Periods: %llu\n", ticks64);
mexPrintf("32-bit manual truncation: %llu\n", ticks32_manual);
mexPrintf("32-bit automatic truncation: %u\n", ticks32_auto);
Run Code Online (Sandbox Code Playgroud)

我的代码的输出如下:

期间:651444791362198

32 位手动截断:1331774102

32 位自动截断:1331774102

我原以为 32 位和原始 64 位表示的最后几位数字相同,但事实并非如此。也就是说,我认为我会“失去 64 位数字的左半部分”。

谁能解释一下这里发生了什么?谢谢。

顺便说一句,我看过这个链接

And*_*own 6

正如评论中所指出的,您的代码操作没有任何问题,只是您没有正确可视化输出。这是您的代码,已更正且可运行:

#include <cstdio>
#include <cstdint>

int main() {
  uint64_t ticks64 = 651444791362198llu;
  uint64_t ticks32_manual = ticks64 & 0xFFFFFFFF;
  uint32_t ticks32_auto = (uint32_t) ticks64;

  printf("Periods: %llX\n", ticks64);
  printf("32-bit manual truncation: %llX\n", ticks32_manual);
  printf("32-bit automatic truncation: %X\n", ticks32_auto);
}
Run Code Online (Sandbox Code Playgroud)

输出是:

Periods: 2507C4F614296
32-bit manual truncation: 4F614296
32-bit automatic truncation: 4F614296
Run Code Online (Sandbox Code Playgroud)