>>>、>>、<<运算(原码、补码、反码)

>>>表示不带符号向右移动二进制数,移动后前面统统补0;两个箭头表示带符号移动,

没有<<<这种运算符,因为左移都是补零,没有正负数的区别。

如 -12 的二进制为:1111  1111  1111  1111  1111  1111  1111  0100;

-12 >> 3 即带符号右移3位,结果是:1111  1111  1111  1111  1111  1111  1111  1110,十进制为: -2;

-12 >>> 3 就是右移三位,前面补零,为:0001  1111  1111  1111  1111  1111  1111  1110,十进制为:536870910。
 

 

在计算机中是以数值是以该数的补码形式来表示.
正数:原码=反码=补码
+12

原码:0,1100
反码:0,1100
补码:0,1100

负数:反码=除符号位原码各位取反; 补码=反码+1
-12

原码:1,1100
反码:1,0011
补码:1,0100

Note:逗号之前为符号位

[x]补码 : 连同符号位在内,每位取反,末位加一,即得到[-x]补码.

例:
8位机器字长,[-2]的补码表示为[11111110]
各位取反(包括符号位)[00000001],末位加一为[00000010]即[2]的补码


8位机器字长,[12]的补码表示为[00001100]
各位取反(包括符号位)[11110011],末位加一为[11110100]即[-12]的补码

System.out.println(Integer.toBinaryString(-12));
System.out.println(Integer.toBinaryString(12));
输出结果:
11111111111111111111111111110100
1100

由结果可看出:计算机中负数的二进制是以负数的补码形式表示

 


<<(左移)和>>(右移)。移位运算符组成的表达式也属于算术表达式,其值为算术值。左移运算是将一个二进制位的操作数按指定移动的位数向左移位,移出位被丢弃,右边的空位一律补0。右移运算是将一个二进制位的操作数按指定移动的位数向右移动,移出位被丢弃,左边移出的空位或者一律补0,或者补符号位,这由不同的机器而定。在使用补码作为机器数的机器中,正数的符号位为0,负数的符号位为1,
 

20的二进制为 0001 0100,右移2位后为 0000 0101,则结果就为 res =5;
res = -20 >> 2;
-20的二进制为 1110 1011,右移2位,此时高位补0,即 0011 1010,结果为 res =- 5;
左移没有<<<运算符!

  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值