在C中将int移位32次

Bla*_*ble 3 c bit-shift

我有一个特定的C位移位方案,我不相信Stack Overflow已经涵盖了.(如果是的话,我一直找不到它!)

本练习使用signed ints作为数据类型.

取值0x80000000(在最重要的位中只是1).

使用算术右移(我的确如此)在机器上右移一次.

结果= 0xC0000000(最左边的字节为1100 0000).

继续移动它,你应该从左到右填充它们.

结果= 0xFFFFFFFF(所有.)

但是: 尝试相同的示例,但一起移动一个额外的位置:

0x80000000 >> 0x00000020 (右移32次)

你的结果?我不知道.我的结果不是全部.事实上,我得到的0x00000001不是我想要的行为.为什么是这样?它是机器特定的吗?

(背景:家庭作业将我的操作限制在一些操作员手中以解决难题.这是一个难题的一个方面,但远不是整个问题.)

sou*_*edi 6

这是未定义的行为

当使用超过32次时,32位整数为什么不按预期工作,为什么不移位"<<"?

这意味着你应该像瘟疫一样避免它.这里有一些链接,包括"每个C程序员应该知道什么是未定义的行为":http://lwn.net/Articles/511767/


unw*_*ind 5

按操作数的位数移动具有未定义的行为,这就是您获得"意外"结果的原因.

  • @BlackVegetable“各种CPU的基础移位操作在此方面具有不同的作用:例如,X86将32位移位量截断为5位(因此,32位移位与0位移位相同)”博客。 llvm.org/2011/05/what-every-c-programmer-should-know.html (2认同)