1.在计算机中,所有数据都是用补码运算的。
2.正数的原码、反码、补码都是一样的
3.负数由原码到补码有两种方式:
3.1第一,先变为反码:符号位不变,其余位取反,然后变补码:+1
3.2第二,先对负数取绝对值,然后将绝对值的整体取反(包括符号位),再+1
如,求-6的补码
//方法一
-6的原码:1000 0110
反码:1111 1001
补码:1111 1010
//方法二
-6的绝对值:6
6的原码:0000 0110
整体取反:1111 1001
+1:1111 1010
虽然两种方法类似,但是在(byte)128这个转换上,使用第二种方法才能得出正确结果
1.-128的原码:00000000 00000000 00000000 10000000
2.由于正数的原码补码相同,故 补码:00000000 00000000 00000000 10000000
3.byte是一字节,int是四字节,因此 int类型强转为byte时 只取最后八位 也就是这里的 10000000
4.但这只是补码,还需要转为原码,才能得到最终的b
//方法一
补码:1000 0000
反码:0111 1111 (补码-1)
原码:0000 0000 (符号位不变,其余位取反)
最终的结果就是0 是不对的
//方法二
补码:1000 0000
-1:0111 1111
整体取反:1000 0000
就可得出原码的绝对值是128, 由于已知是个负数
所以最终的结果就是-128
也可以这样理解
128超过了byte的范围,内存溢出 就是-128
129就是-127
—|——————|—|———————|———
-128 127 -128 127
补充:
byte的取值范围是从 -128 (-2^7) ~127 (2^7-1) 10000000-01111111
11111111-01111111能从-127表示到127,但由于+0和-0都代表0,重复了,所以让-0代表-128。