在C中将int移位32次
我有一个特定的C位移位方案,我不相信Stack Overflow已经涵盖了. (如果是的话,我一直找不到它!)
本练习使用signed ints作为数据类型. 取值0x80000000(在最高位中只是1.) 使用算术右移(我的确如此)在机器上右移一次. 结果= 0xC0000000(最左边的字节为1100 0000). 继续移动它,你应该从左到右填充它们. 结果= 0xFFFFFFFF(全部.) 但是:尝试相同的示例,但一起移动一个额外的位置: 0x80000000>> 0x00000020(右移32次) 你的结果?我不知道.我的结果不是全部.事实上,我得到了0x00000001这不是我想要的行为.为什么是这样?它是机器特定的吗? (上下文:家庭作业将我的操作限制在几位运算符手中以解决难题.这是一个难题的一个方面,但远不是整个问题.) 解决方法
这是未定义的行为
Why doesn’t left bit-shift,“<<“,for 32-bit integers work as expected when used more than 32 times? 这意味着你应该像瘟疫一样避免它.这里有一些链接,包括“每个C程序员应该知道什么是未定义的行为”:http://lwn.net/Articles/511767/ (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |