包装类详解(装箱(包)、拆箱(包)、Integer类型缓存)

简介: 包装类详解(装箱(包)、拆箱(包)、Integer类型缓存)

在 Java 中,由于基本类型不是继承自 Object ,为了在泛型代码中可以支持基本类型, Java 给每个基本类型都对应了一个包装类型。


一、基本数据类型和对应的包装类


1667913560024.jpg


除了 Integer 和 Character, 其余基本类型的包装类都是首字母大写。


二、装箱和拆箱


装箱操作,新建一个 Integer 类型对象,将a的值放入对象的某个属性中

int a = 10;
        Integer a1 = a;            //自动装箱
        Integer a2 = (Integer) a;  //自动装箱
        Integer a3 = new Integer(a);    //手动装箱
        Integer a4 = Integer.valueOf(a);//手动装箱

拆箱操作,将 Integer 对象中的值取出,放到一个基本数据类型中

int b = a1.intValue();  //手动拆箱
        int b1 = a1;            //自动拆箱
        int b2 = (int) a1;      //自动拆箱
        float b3 = a1.floatValue();  //手动拆箱
        double b4 = a1.doubleValue(); //手动拆箱


三、Integer类型把[-128~127]的数据缓存了,这个范围的数据直接取出,不需要新new对象。


思考题:输出结果是什么?


public static void main(String[] args){
        Integer a = 127;
        Integer b = 127;
        Integer c = 128;
        Integer d = 128;
        System.out.println(a == b);
        System.out.println(c == d);
}

答案是:true false


这里就涉及到了装箱的问题,装箱的时候会调用到valueOf方法。我们进入valueOf的原码,就可以看到:

public static Integer valueOf(int i) {
        if (i >= IntegerCache.low && i <= IntegerCache.high)
            return IntegerCache.cache[i + (-IntegerCache.low)];
        return new Integer(i);
    }

1667913631342.jpg

通过输出的结果不难推测出,当a=b=127的时候,应该是进了If语句,没有new 对象就返回了,所以a和b是相等的。当a=b=128的时候,应该是new Integer(i),所以不相等。


接下来继续看源码,继续看看具体的原因是什么?


1667913645764.jpg


不难看出,当 i 的值在-128和127之间[-128,127],就会进入If语句。


接下来,再看cache具体是什么?


1667913659098.jpg


cache是一个数组,而且被static final 修饰,它所指向的数组对象不能被改变。-128~127之间共有256个数据,比如现在i=-128,那么就会在数组的-128 + (-(-128))= 0,即0下标取出-128。即最大值能取出127,即下标为255。这样就能够解释为什么 127能够相等,128就不相等了,因为当为128的时候,此时需要new 对象。


那么这样做的好处是什么呢???


其实这样做的好处就是,一些频繁使用的小的数据就不要每次都去new了。


相关文章
|
存储 缓存 Java
【面试题精讲】Java包装类缓存机制
【面试题精讲】Java包装类缓存机制
|
8月前
|
缓存 中间件 数据库
中间件缓存策略类型
【5月更文挑战第6天】中间件缓存策略类型
58 2
中间件缓存策略类型
|
8月前
|
缓存 Linux 应用服务中间件
linux yum下载离线包缓存 安装到服务器 实测!!!
linux yum下载离线包缓存 安装到服务器 实测!!!
153 0
|
8月前
|
存储 缓存 Java
Java中的Integer缓存池
Java中的Integer缓存池
71 0
|
缓存 JSON NoSQL
Map<Integer,Value>放入缓存后取出来变成了Map<String,Value>
Map<Integer,Value>放入缓存后取出来变成了Map<String,Value>
230 0
|
存储 缓存 Java
Java基础:128陷阱之Integer缓存源码研究
Java基础:128陷阱之Integer缓存源码研究
212 0
Java基础:128陷阱之Integer缓存源码研究
|
缓存 Java
Java包装类缓存机制
首先,来看一道常见的面试题,下面代码运行后会输出什么?
126 0
|
缓存 Java
Java中基本类型和包装类的各类比较(==),以及包装类的对象缓存池
Java中的`基本类型`及其`包装类的比较(==)`一直是一个比较头疼的问题,不仅有`自动装箱和拆箱`操作,部分的包装类还有对象`缓存池`,这就导致了这部分知识容易混淆。 对于`==`操作符来说,如果比较的数据是`基本类型`,则比较它们的`值`,如果比较的是`对象`,则会比较`对象的内存地址`。另外,如果一个是基本类型、一个是包装类型,在比较前会先把包装类型`拆箱`成基本类型,然后进行比较。
|
缓存 Java
才知道,Integer中的缓存范围竟然可以修改
才知道,Integer中的缓存范围竟然可以修改
258 0
|
缓存
缓存区的类型
缓存区的类型
160 0