Integer 缓存

在 Java 中,如果你通过 new Integer(value) 显式创建一个 Integer 对象,以下几点需要注意:

内存中的 Integer 对象

  1. 缓存范围

    Java 自动缓存的 Integer 对象范围是从 -128127。这些对象在类加载时被创建并存储在内存中。

  2. 使用 new 创建对象

    当你使用 new Integer(value) 创建一个整数对象时,无论 value 的值是 -1270100 还是 128,都会创建一个新的 Integer 对象。即使这个值在缓存范围内,new 关键字也不会返回缓存中的对象。

sql 复制代码
`Integer a = new Integer(100);   // 创建新对象
Integer b = new Integer(100);   // 又创建一个新对象
System.out.println(a == b);      // 输出: false`
  1. 缓存对象的存在

    缓存的对象在内存中始终存在,直到 JVM 结束。你可以通过 Integer.valueOf(int value) 方法获取缓存对象。

sql 复制代码
   
Integer c = Integer.valueOf(100);   // 使用缓存
Integer d = Integer.valueOf(100);   // 同样使用缓存
System.out.println(c == d);          // 输出: true

import java.util.HashMap;
import java.util.Map;

public class IntegerCache {
private static final Map<Integer, Integer> cache = new HashMap<>();

static {
    for (int i = -128; i <= 127; i++) {
        cache.put(i, i);
    }
}
public static Integer valueOf(int value) {
    return cache.getOrDefault(value, new Integer(value));
}

public static void main(String[] args) {
    Integer a = IntegerCache.valueOf(100);
    Integer b = IntegerCache.valueOf(100);
    System.out.println(a == b);  // 输出: true

    Integer x = IntegerCache.valueOf(200);
    Integer y = IntegerCache.valueOf(200);
    System.out.println(x == y);  // 输出: false
}


}

总结

  • 使用 new Integer(value) 会创建新对象,而不会使用缓存的对象。
  • 缓存的 Integer 对象(-128 到 127)在内存中始终存在,但通过 new 创建的对象不会与这些缓存对象相同。
  • 若要利用缓存,使用 Integer.valueOf(int) 方法是最佳选择。
  • 返回缓存对象 :当你调用 Integer.valueOf(int value) 时,该方法会检查传入的值是否在缓存范围内(-128 到 127)。如果是,它会返回缓存中的对象,而不是创建新的对象。
sql 复制代码
`public static Integer valueOf(int i) {
    if (i >= Integer.MIN_VALUE && i <= 127) {
        return IntegerCache.cache[i + 128]; // 返回缓存中的对象
    }
    return new Integer(i); // 超出范围时,创建新对象
}`
相关推荐
Zfox_2 小时前
Redis:渐进式遍历
服务器·数据库·redis·缓存
CHEN5_0213 小时前
Redis分布式缓存(RDB、AOF、主从同步)
redis·分布式·缓存
在肯德基吃麻辣烫18 小时前
《Redis》持久化
数据库·redis·缓存
sclibingqing1 天前
SpringBoot项目使用Redis作为数据缓存
spring boot·redis·缓存
珹洺1 天前
MyBatis实战指南(七)MyBatis缓存机制
java·数据库·sql·安全·缓存·oracle·mybatis
奈斯ing2 天前
【prometheus+Grafana篇】基于Prometheus+Grafana实现Redis数据库的监控与可视化
数据库·redis·缓存·grafana·prometheus
CHEN5_022 天前
Redis相关知识总结(缓存雪崩,缓存穿透,缓存击穿,Redis实现分布式锁,如何保持数据库和缓存一致)
数据库·redis·分布式·缓存
Villiam_AY2 天前
redis主从复制
数据库·redis·缓存
~Yogi2 天前
今日学习:Spring线程池|并发修改异常|链路丢失|登录续期|VIP过期策略|数值类缓存
学习·spring·缓存
开航母的李大3 天前
【中间件】Web服务、消息队列、缓存与微服务治理:Nginx、Kafka、Redis、Nacos 详解
前端·redis·nginx·缓存·微服务·kafka