如何将32位有符号整数放入64位无符号整数的高32位?

时间:2016-06-08 11:58:14

标签: c++ bit-shift

示例:

qint32 si32 = -1; // that gives us 0xFFFFFFFF
quint64 ui64 = si32; // that gives us 0xFFFFFFFFFFFFFFFF, that is expected

期望的结果:

0xFFFFFFFF00000000

当我试图像这样在si32上移位时

quint64 ui64 = si32 << 32;

编译器警告我有关位移溢出的信息。

这应该是一项简单的任务,但我无法弄清楚如何做到这一点。 这是一个unix C ++代码(使用QT,但这并不重要,简单的unix C ++代码会这样做。)

感谢您的帮助。

1 个答案:

答案 0 :(得分:7)

警告与si32本身的大小有关。基本上步骤的顺序如下:

  1. si32(32位值)
  2. 将该值移位32位(即将32位值移位32位)
  3. 将其分配给ui64
  4. 要解决此问题,您可以先将si32转换为正确的64位类型,然后再将其移位32位,这样位移位将以64位值运行:

    quint64 ui64 = ((quint64) si32) << 32;