(1).二进制中负数的计算
负数以正数的补码表示
原码:一个整数按照绝对值的大小转化成二进制的数
反码:将二进制数按位取反
补码:反码加 1
以-14 举例
原码:14 即 00000000 00000000 00000000 00001110
反码: 11111111 11111111 11111111 11110001
补码: 11111111 11111111 11111111 11110010
所以-14 的二进制是 11111111 11111111 11111111 11110010
假设 我们得到 二进制让我们求整数 就是倒着来取相反数
如二进制是 11111111 11111111 11111111 11110010
得到反码减1 11111111 11111111 11111111 11110001
原码: 00000000 00000000 00000000 00001110
即 1110 = 14 所以取反 就是-14
(2).<<左移运算符
1.将一个运算对象的各二进制位全部左移若干位(左边的二进制丢弃,右边补0)
(注意:java中 整数位 32位)
11 << 2 = 44
-14 <<2 =-56
-14的二进制(11111111 11111111 11111111 11110010)左移2位 为
11111111 11111111 11111111 11001000 结果为