上篇文章留了一个问题
byte b=(byte)130;System.out.println(b);
b的值为多少呢?
答案为: -126
我们都知道byte的取值范围为-128~127,那么这个看似离谱的答案,是如何得出的呢。
Java的编码机制
要解决这个问题,首先要了解Java的编码机制。根据前面所学的知识,我们知道byte占用的空间为8位,short占16位,int占32位,long占64位。
这里的“位”指的就是占二进制的位数。8位就由八个0或1组成。
符号位
其中,第一位不表示具体的值,而是表示正负。1表示负,0表示正。
这样一来,byte的取值范围也就能说的通了,当第一位为0时,后7位二进制转换为10进制就是=128,再减去一个0,所以正值最大取到127;负值则不需要减去一个0,最小可以取到-128,其他类型也是同理。
原码、补码、反码
Java中,正数用原码*表示,负数用补码*表示
*原码:就是一个数的二进制
*补码:正数原码本身,负数反码*+1
*反码:正数原码本身,符号位不变,负数原码按位取反
根据以上的注解呢,就可以得出当符号位为1时,也就是负数的情况下
补码=反码+1
正题开始
在这个题中,130为int型,int型为32位
0000 0000 0000 0000 0000 0000 1000 0010
将int型强转为byte型时,系统将会截取32位的最后8位,即
1000 0010
这串二进制的数值即为原码。
符号位为1,说明二进制为负数,而负数要用补码表示
根据上面的式子,补码=反码+1。由1000 0010可得
反码(符号位不变)
1111 1101
补码=反码+1
补码
1111 1110
因为在Java中负值用补码表示,将 111 1110(空出符号位)转换为10进制,结果为126,再加上符号位1代表的负号,结果就是-126