二进制的深入理解
- 11 1111
- 这个值为多少呢?其实就是(
2**6
) - 1 ;所以是63,因为补码从右到左依次是从2**0
,2**1
,2**2
,2**3
…,也就是按坐标0开始,因为11 1111
这个数如果加+1
,那就是100 0000
,所以11 1111
,的数也可以表示为(2**6) - 1
,即63。
- 这个值为多少呢?其实就是(
原码
计算规则:十进制数据的二进制表现形式,最左边为符号位,0为正,1为负(超出部分不管)
- 1 byte == 8bit,即 1byte 最大为127,二进制表现形式
0111 1111
,则最小为1111 1111
,即-127因为补码的出现所以1000 000 为-128
原码弊端:利用原码进行计算的时候,如果是正数完全没有问题,但如果是负数计算,结果就出错,实际运算的反向,跟正确的运算反向是相反的
反码
反码出现的目的:为了解决原码不能计算负数的问题而出现的
计算规则:正数的反码不变,负数的反码在原码的基础上,符号位不变。数值取反,0变1,1变0
反码的弊端:负数运算的时候,如果结果不跨0,是没有任何问题的,但是如果结果跨0,跟实际结果会有1的偏差
补码
补码出现的目的:为了解决负数计算时跨0的问题而出现的
计算规则:正数的补码不变,负数的补码在反码的基础上+1。另外补码还能多记录一个特殊的值-128,该数据在1个字节下,没有补码和反码
注意点:计算机中的存储和计算都是以补码的形式进行的。