jdk源码之自动装拆箱
来源:互联网 发布:对json进行url编码 编辑:程序博客网 时间:2024/06/05 21:52
前言
在讲自动转拆箱之前,我先出一个题目吧,如果能够答对并且知道为什么,那么久不用看本篇了。
public static void main(String[] args) { Integer i = 128 ; // 装箱 Integer j = 128 ; Integer x = 1 ; // 装箱 Integer y = 1 ; System.out.println(i == j); // false System.out.println(x == y); // true }
其实在我们学习java基础的时候学过装箱拆箱的概念,可能你当时只是理解为Integer和int能够自动转换,而并没有深究是怎么实现的。OK,只好查看源码了。
分析
List<Integer> list = new ArrayList<Integer>();list.add(1);
如果你在第二行代码debug的话,肯定会进入到。
public static Integer valueOf(int i) { if (i >= IntegerCache.low && i <= IntegerCache.high) return IntegerCache.cache[i + (-IntegerCache.low)]; return new Integer(i);}
从上面可以知道
如果i的值在-128~127之间,则从缓存中取,否则直接创建一个Integer对象.
我们再来看看IntegerCache
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() {} }
上面代码在static块里。
现在可以解释前言中的问题了,如果一个值在-128~127之中,则会直接在缓存中取,否则会直接创建一个Integer对象。所以上面i == j 为false。
总结
有些东西看着很简单,但是容易掉坑哦~~~
阅读全文
0 0
- jdk源码之自动装拆箱
- JDK源码之Map
- jdk源码之Map
- JDK源码之AbstractCollection
- JDK源码之-HashMap
- jdk源码之String
- JDK源码分析之String
- JDK源码学习之ArrayList
- JDK源码学习之String
- JDK源码学习之HashMap
- JDK源码学习之前言
- JDK源码阅读之ArrayList
- JDK源码阅读之LinkedList
- 深入源码之JDK Logging
- JDK源码阅读之Arrays
- JDK源码阅读之String
- JDK源码阅读之AbstractList
- JDK源码阅读之AbstractMap
- 第一次反编
- 过渡与动画
- COUNT()函数使用时数据溢出-->COUNT_BIG
- [资源分享][Unity好文章]实现网球乒乓球回弹的效果
- CSS可见性
- jdk源码之自动装拆箱
- CSS之内容移出
- Remove Extra One Codeforces Round #450 (Div. 2)(线段树)
- emmet语法总结
- 滑动门
- 为什么 JakeWharton 建议:App 只要用到一个 Activity ?
- Shader山下(二十九)基于渲染路径的优化
- 现代操作系统之安全(上)
- JSTree使用