gpt4 book ai didi

c++ - 左移带有可变误差

转载 作者:行者123 更新时间:2023-11-30 18:30:30 26 4
gpt4 key购买 nike

我正在尝试创建一个掩码,但是当我计算 shift 的值并将其放入变量中时,我得到了错误的结果。看:

#include <stdio.h>

int main(){
int shift = 32 ;
printf("%d\n",shift); //32
int mask = 0xFFFFFFFF << shift;
printf("%x\n",mask); //ffffffff
mask = 0xFFFFFFFF << 32;
printf("%x\n",mask); //00000000
return 0;
}

有人知道为什么会发生这种情况吗?

最佳答案

如果您的系统有 32 位或更小的 int,那么您会导致 undefined behaviour通过移位 32 位或更多。移位的位数必须少于类型的位数。

如果你有 64 位 int,那么 0xFFFFFFFF 将是一个有符号 int,将其移位 32 位会将 1 移动到符号位,这会导致 UB在 C 中,以及在 C++14 之前的 C++ 中。 (从 C++14 开始,这会导致实现定义的行为)。

如果在 64 位情况下按计划进行移位,

printf("%x\n",mask); 也会触发 UB,因为 %x 需要非负值,但您将传递负 int。为了避免这种情况,请改用unsigned int mask

当你触发UB时,任何事情都可能发生,包括但不限于无意义的输出,以及相同的操作给出不同的结果。

关于c++ - 左移带有可变误差,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30677965/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com