我有一个特定的C位移位方案,我不相信Stack Overflow已经涵盖了.(如果是的话,我一直找不到它!)
本练习使用signed ints作为数据类型.
取值0x80000000(在最重要的位中只是1).
使用算术右移(我的确如此)在机器上右移一次.
结果= 0xC0000000(最左边的字节为1100 0000).
继续移动它,你应该从左到右填充它们.
结果= 0xFFFFFFFF(所有.)
但是: 尝试相同的示例,但一起移动一个额外的位置:
0x80000000 >> 0x00000020 (右移32次)
你的结果?我不知道.我的结果不是全部.事实上,我得到的0x00000001不是我想要的行为.为什么是这样?它是机器特定的吗?
(背景:家庭作业将我的操作限制在一些操作员手中以解决难题.这是一个难题的一个方面,但远不是整个问题.)
这是未定义的行为
当使用超过32次时,32位整数为什么不按预期工作,为什么不移位"<<"?
这意味着你应该像瘟疫一样避免它.这里有一些链接,包括"每个C程序员应该知道什么是未定义的行为":http://lwn.net/Articles/511767/
按操作数的位数移动具有未定义的行为,这就是您获得"意外"结果的原因.
| 归档时间: |
|
| 查看次数: |
8027 次 |
| 最近记录: |