左移和右移都是位运算的概念。我们知道计算机是基于二进制保存数据的,因此左移和右移的概念十分重要。本文约定是32位的机器
[左移] 丢弃最高位,0补最低位
左移是把一个数按照二进制每位向左移动若干位,在c语言中用运算符 << 表示。例如:
int x = 1;
x = x << 2; //把x的值左移2位
[右移] 丢弃最低位,符号补高位
右移的概念和左移正好相反,是指的向右移动若干位,在c语言中用运算符 << 表示。
相比较左移来说,右移稍稍复杂一点。我们分为 有符号整数 和 无符号整数 来说明。
对于无符号整数,右移可以直接看做是除以2的n次方的运算,且有整数除法的概念,低位移出去的位全部丢弃。举个简单的例子来说,十进制的5对应的二进制的表示为101,它右移1位得到的数会是2,也就是二进制表示的10,右端的1直接被丢弃掉了。
对于有符号整数,右移会保持符号位不变。例如:
int x = 0x80000000; //对应二进制的1000……0000
x = x >> 1; //x的值不会变成0x40000000(二进制的0100……0000),而是变成0xc0000000(二进制的1100……0000)
也就是说,符号位向右移动后,如果之前是正数,就在最高位补0;如果是负数,就在最高位补1(这样的方式还是与负数用补码存储有关)。这也是汇编语言中的算术右移。
转载自https://www.cnblogs.com/CQBZOIer-zyy/p/5257517.html
最后
以上就是淡定服饰最近收集整理的关于计算机中的左移和右移的全部内容,更多相关计算机中内容请搜索靠谱客的其他文章。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复