1.左移操作符(<<):
左移操作符将数字的二进制表示向左移动指定的位数。右侧空出的位用0填充。左移操作相当于乘以2的幂。
例如:
int num = 4; // 二进制表示为 0100
int shifted = num << 1; // 结果为 8,二进制表示为 1000
2.带符号右移操作符(>>):
带符号右移操作符将数字的二进制表示向右移动指定的位数。左侧空出的位用符号位(正数为0,负数为1)填充。右移操作相当于除以2的幂(向下取整)。
例如:
int num = 8; // 二进制表示为 1000
int shifted = num >> 1; // 结果为 4,二进制表示为 0100
- 无符号右移操作符(>>>):
无符号右移操作符与带符号右移操作符类似,但它总是用0来填充左侧空出的位,无论原数的符号是什么。
例如:
int num = -8; // 二进制表示为 1111 1000(补码表示)
int shifted = num >>> 1; // 结果为 2147483644,二进制表示为 0111 1100 0000 0000 ... 0000
在这个例子中,我们将-8(在二进制补码表示中为1111 1000)无符号右移1位,得到2147483644(在二进制中表示为0111 1100 0000 0000 … 0000)。
注意:对于负数,其二进制表示通常使用补码形式。在补码表示中,最高位(符号位)为1表示负数,为0表示正数或零。右移时,带符号右移会保持符号位不变,而无符号右移则总是用0填充。
原码、反码和补码都是计算机中对数字的二进制定点表示方法,常用于处理整数的存储和运算。
另:
原码是一种直观的二进制表示法,其中最高位为符号位,用来表示数字的正负,其余位表示数值的大小。符号位为0表示正数,为1表示负数。例如,8位二进制数中,+1的原码为0000 0001,-1的原码为1000 0001。
反码主要用于系统环境设置,如Linux平台的目录和文件的默认权限设置。正数的反码与原码相同,而负数的反码是在其原码的基础上,符号位不变,其余各位取反。例如,-1的原码为1000 0001,其反码则为1111 1110。
补码则是一种用于计算机中二进制数运算的数字表示法,特别是用于简化加减法运算。正数的补码与其原码相同,而负数的补码是在其反码的基础上加1。补码的一个重要特性是对于任意一个整数n,它的补码与-n的补码相同。这使得计算机能够使用相同的加法器进行正数和负数的加法运算,从而简化了运算逻辑。