Integer缓存IntegerCache详解
发布日期:2021-06-30 11:12:44
浏览次数:3
分类:技术文章
本文共 2582 字,大约阅读时间需要 8 分钟。
版权声明
- 本文原创作者:谷哥的小弟
- 作者博客地址:http://blog.csdn.net/lfdfhl
引子
今天,我们从一段非常简单的代码说起。
示例代码
package cn.com;/*** 本文作者:谷哥的小弟 * 博客地址:http://blog.csdn.net/lfdfhl* 示例描述:Integer缓存IntegerCache*/public class IntegerCacheTest { public static void main(String[] args) { Integer a=9527; Integer b=9527; System.out.println(a==b); Integer c=97; Integer d=97; System.out.println(c==d); }}
运行结果
请问,这段代码运行的结果是什么呢?两次输出的结果都是false,对不对?非也!!!
从上图可以清楚地看到:- 1、第一次输出的结果是false
- 2、第二次输出的结果是true
看此处,就有点丈二和尚摸不着头脑了。这是为什么呢?
源码剖析
在执行Integer a=9527;时会调用Integer类的静态方法public static Integer valueOf(int i)进行自动装箱,其源码如下:
public static Integer valueOf(int i) { if (i >= IntegerCache.low && i <= IntegerCache.high) return IntegerCache.cache[i + (-IntegerCache.low)]; return new Integer(i); }
该方法的主要逻辑如下:
- 如果i >= IntegerCache.low && i <= IntegerCache.high则调用IntegerCache.cache[i + (-IntegerCache.low)]
- 如果i的值不满足i >= IntegerCache.low && i <= IntegerCache.high则调用new Integer(i)
顺着这条主线,我们继续探究Integer缓存IntegerCache。IntegerCache是Integer类中的静态内部类,用于缓存数据便于节省内存、提高性能。其源码如下:
private static class IntegerCache { static final int low = -128; static final int high; static final Integer cache[]; static { // high value may be configured by property int h = 127; String integerCacheHighPropValue = sun.misc.VM.getSavedProperty("java.lang.Integer.IntegerCache.high"); if (integerCacheHighPropValue != null) { try { int i = parseInt(integerCacheHighPropValue); i = Math.max(i, 127); // Maximum array size is Integer.MAX_VALUE h = Math.min(i, Integer.MAX_VALUE - (-low) -1); } catch( NumberFormatException nfe) { // If the property cannot be parsed into an int, ignore it. } } high = h; cache = new Integer[(high - low) + 1]; int j = low; for(int k = 0; k < cache.length; k++) cache[k] = new Integer(j++); // range [-128, 127] must be interned (JLS7 5.1.7) assert IntegerCache.high >= 127; } private IntegerCache() { } }
从这里我们可以看出 :
- IntegerCache.low = -128
- IntegerCache.high = 127
- 缓冲区cache是一个Integer类型的数组
也就是说:IntegerCache缓存区间为[-128,127]。所以,在调用Integer.valueOf(int i)方法进行自动装箱时假若i的值在[-128,127]区间则生成的Integer对象会被存入缓冲区。当再次对该值进行装箱时会先去缓冲区中获取;如果取到则返回,如果没有取到则创建包装类对象存入缓冲区并返回。
嗯哼,看到这里是不是可以理解之前的那小段代码了呢?
扩展与延伸
除了Integer之外,在其他包装类(例如:Byte,Short,Long等)中也存在类似的设计。
转载地址:https://it9527.blog.csdn.net/article/details/110221963 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!
发表评论
最新留言
第一次来,支持一个
[***.219.124.196]2024年04月23日 22时05分51秒
关于作者
喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!
推荐文章
CSS3 学习+实践
2019-04-30
基于html5拖(drag)放(drop)实现换装小游戏
2019-04-30
js基础
2019-04-30
jQuery的deferred对象详解
2019-04-30
js创建对象的几种方式
2019-04-30
ASP.NET -- 获取浏览器信息
2019-04-30
sql server 性能优化方法
2019-04-30
Sql Server 数据库扩展
2019-04-30
SQL Server2012高可用之日志传送测试
2019-04-30
Python 程序员写了五个实战游戏案例,让我学起来更加有动力了
2019-04-30
我们普通人和薇娅、李佳琦等人的差距到底在哪里?
2019-04-30
如何成为一个合格的程序员男朋友
2019-04-30
毫无头绪的自学Python,你可能连门槛都摸不到!【最佳学习路线】
2019-04-30
我说这些Python工具包很实用并且强大,你反对吗?
2019-04-30
torch.nn.Embedding的使用
2019-04-30
排序算法(五)快速排序的实现(python)
2019-04-30
使用邻接表实现数据结构图(python)
2019-04-30
图的非递归深搜遍历图示与代码(python)
2019-04-30
100条养生、养心秘笈,值得一看
2019-04-30
必须掌握的30种SQL语句优化
2019-04-30