本练习使用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/
总结以上是内存溢出为你收集整理的在C中将int移位32次全部内容,希望文章能够帮你解决在C中将int移位32次所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)