我们都知道,java中byte占用一个字节,short、char占用两个字节,但是byte、short、char在java底层中存储实际上32位的补码,只不过在定义变量的时候默认加上了一个强制类型转换来限制它的大小。
证明:
代码:
public class Test{
public static void main(String[] args){
byte a = -5;
System.out.println(a>>>2);
}
}
输出结果:1073741822
如果byte类型在底层存储为8位,那么:
-5补码:
原码:10000101
反码:11111010
补码:11111011
运算之后得到的补码:00111110
我们知道正数的原反补是相同的,所以运算之后得到的原码为:00111110,转换成十进制为62,结果输出应该为62,但是实际上输出的结果远远要大于62.那是为什么呢?
原因就在于byte类型在java底层是以32位补码的形式进行存储和表示的,下面进行证明。
-5的32位补码:
原:10000000 00000000 00000000 00000101
反:11111111 11111111 11111111 11111010
补:11111111 11111111 11111111 11111011
在>>>2运算之后得到的补码:
00111111 11111111 11111111 11111110
转换成原码:
00111111 11111111 11111111 11111110
再转换成十进制为:1073741822。正好和我们看到的输出结果相同,所以得出结论:byte、short、char类型在java底层是以32位补码的形式进行存储和表示的