从 64 位整数中提取 32 位

extract 32bit from 64bit integer

我有一个uint64_t整数,通过以下代码将最后32位提取成一个uint32_t数字:

uint32_t getLast(uint64_t v){
      uint64_t t= v >> 32;
      return  reinterpret_cast<uint32_t &>( t ); // type-punned pointer warning
}

int main()
{
    uint64_t a = 1l << 33 | 1l << 3;
    std::cout << getLast(a) << std::endl; // prints 2
}

此代码发出警告:

warning: dereferencing type-punned pointer will break strict-aliasing rules [-Wstrict-aliasing]
       return  reinterpret_cast<uint32_t &>( t );

我想解决这个问题,但不是使用联合类型。

reinterprete_cast 在访问数据时给出未定义的行为(将重新解释的内容复制到 return 值中)(我认为?)

另一个似乎有效的解决方案?

 uint32_t getLast(uint64_t v){

    return (v >> 32) // conversion from bitshifted 64bit to 32bit, but what is with overflow?
 }

我有点困惑,关于 reinterpret_cast 的未定义行为? 那么我应该如何使用reinterpret_cast,我认为这个例子是典型的使用模式?第二种方法也安全吗?

你应该static_cast<uint32_t>reinterpret_cast 几乎专门用于高度狡猾且可能是非法的指针转换。