#原码 反码 补码的定义与运算 ##1原码: 原码是将十进制或者其他进制的数转换为二进制表示(且要根据数据的类型转换) 如:130 (默认是Int类型,则是4个字节) 原码是:00000000 00000000 00000000 100000010
##2反码: 1.当原码是正数时,反码就是原码 2.当原码是负数时,反码是除了第一位的符号位以外的位数全部取反
##3补码: 1.当原码是正数时,反码就是原码 2.当原码是负数时,补码是反码+1
#计算机操作中对数据的分析过程:
计算机中的数据运算是用数据的补码进行的,但是显示出来是用数据的原码,及原码显示,对补码进行操作
A: 获取130的二进制原码(数据默认是int类型)
00000000 00000000 00000000 10000010
B:对数据130的原码取补码进行截断操作(130的补码就是原码),截成byte(1个字节8位)则变为 10000010
C:将截断得到的byte类型的补码用原码表示(计算机显示是用原码显示)
即是已知补码求原码
反码= 补码-1 :反码=1 0000010 - 1 = 1 0000001
原码=反码取反(除去符号位以外的位) 原码 = 1 1111110
D: 得到的显示的数为 - 126
#byte值的问题
byte 的范围是 -128 ~ 127
128 : 10000000
-128 : 10000000 (这的1既是符号位,也是数值位)
上接byte类型的强制转换有byte b1 = 127; // OK
byte b1 = byte(128); //需要强制转换 得-128
byte b1 = byte(129); //需要强制转换 得-127
byte b1 = byte(130); //需要强制转换 得-126