java中byte、short、char在底层存储

我们都知道,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位补码的形式进行存储和表示的

 

 

 

 


版权声明:本文为qq_41269273原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。