计算机都以 补码形式存在:
1.正数的原码、反码、补码都一样
负数的补码==原码(除符号位) 按位取反再+1;原码==补码(除符号位)按位取反再+1;
十进制 | 原码 | 反码 | 补码 | ||||
|
|
|
| ||||
|
|
|
|
2.计算机为何以补码形式存在
a.无法进行减法运算
b. +0 和-0 该如何表示
java 程序 ,一个byte 范围是 -128~127
byte bb= 130; 会报错,为什么?
bb=10000010,如果 是一个字节表示,那么表示的是负数,存的是负数的补码,求得原码是:-126;11111110;
所以需要强制转换:
byte bb=(byte)130; //补码
sout(bb)== -126;//补码存在100000010
但是如果用2个字节表示,那么就是一个正数0000 0000 10000010 ,求得原码是:130;
java >127的时候,不能再以正数表示了,是有符号的。
给底层发数据,并不关心我们的正负,收到的就是:100000010
0111 1111(2) ==7F(16),大于 7F 的,都变成负的了。80(16)==-128(10)==1000 0000(2)