1. 计算机在任何情况下都只能识别二进制。
2. 计算机在底层存储数据的时候,一律存储的是“二进制的补码形式”。计算机采用补码形式存储数据的原因是:补码形式效率最高。
3. 对于一个正数来说:二进制原码、反码、补码是同一个,完全相同。
int i = 1;
对应的二进制原码:00000000 00000000 00000000 00000001
对应的二进制反码:00000000 00000000 00000000 00000001
对应的二进制补码:00000000 00000000 00000000 00000001
4. 对于一个负数来说:二进制原码、反码、补码的关系:
byte i = -1;
对应的二进制原码:10000001(首位是符号位,1表示负号)
对应的二进制反码:11111110(符号位不变,其它位取反)
对应的二进制补码:11111111(反码+1)
5. 举例分析 byte b = (byte)150;
int类型的4个字节的150的二进制码是:00000000 00000000 00000000 10010110
将以上的int类型强制类型转为1个字节的byte,最终在计算机中的二进制码是:10010110
注意:计算机永远存储的都是二进制补码形式。
即10010110 这个是一个二进制补码形式,可以采用逆推导的方式推算出二进制原码。
10010110 ---> 二进制补码形式
10010101 ---> 二进制反码形式
11101010 ---> 二进制原码形式
11101010 = -106
public class Test{
public static void main(String[] args){
byte b = (byte)150;
System.out.println(b); // -106
}
}