Java中Integer的valueOf方法,-128到127的整数将被缓存
2016-03-23 10:17
483 查看
Java中int和Integer使用==比较将Integer拆箱成int后比较大小(jdk版本不小于1.5)
Integer和Integer之间==比较,是对象之间的比较,看两个引用是否指向同一个内存地址
但是一个字节的整数-128到127之间的整数将被缓存至IntegerCache
所有一个字节大小的Integer都存储于IntegerCache中,new创建的除外
在jdk1.5的环境下,有如下4条语句:
以下输出结果为false的是:
"D:\Program Files\Java\jdk1.8.0_45\bin\java"...
true
true
false
true
Process finished with exit code 0
Integer i01=59 的时候,会调用 Integer 的 valueOf 方法,
这个方法就是返回一个 Integer 对象,只是在返回之前,看作了一个判断,判断当前 i 的值是否在 [-128,127] 区别,且 IntegerCache 中是否存在此对象,如果存在,则直接返回引用,否则,创建一个新的对象。
在这里的话,因为程序初次运行,没有 59 ,所以,直接创建了一个新的对象。
int i02=59 ,这是一个基本类型,存储在栈中。
Integer i03 =Integer.valueOf(59); 因为 IntegerCache 中已经存在此对象,所以,直接返回引用。
Integer i04 = new Integer(59) ;直接创建一个新的对象。
System. out .println(i01== i02); i01 是 Integer 对象, i02 是 int ,这里比较的不是地址,而是值。 Integer 会自动拆箱成 int ,然后进行值的比较。所以,为真。
System. out .println(i01== i03); 因为 i03 返回的是 i01 的引用,所以,为真。
System. out .println(i03==i04); 因为 i04 是重新创建的对象,所以 i03,i04 是指向不同的对象,因此比较结果为假。
System. out .println(i02== i04); 因为 i02 是基本类型,所以此时 i04 会自动拆箱,进行值比较,所以,结果为真。
Integer和Integer之间==比较,是对象之间的比较,看两个引用是否指向同一个内存地址
但是一个字节的整数-128到127之间的整数将被缓存至IntegerCache
所有一个字节大小的Integer都存储于IntegerCache中,new创建的除外
public static Integer valueOf(int i) { if (i >= IntegerCache.low && i <= IntegerCache.high) return IntegerCache.cache[i + (-IntegerCache.low)]; return new Integer(i); }
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; ... high = h; cache = new Integer[(high - low) + 1]; int j = low; for(int k = 0; k < cache.length; k++) cache[k] = new Integer(j++); ... } private IntegerCache() {} }
在jdk1.5的环境下,有如下4条语句:
System.out.println(i01== i02);
System.out.println(i01== i03);
System.out.println(i03== i04);
System.out.println(i02== i04);
Integer i01=59; int i02=59; Integer i03=Integer.valueOf(59); Integer i04=new Integer(59); System.out.println(i01==i02); System.out.println(i01==i03); System.out.println(i01==i04); System.out.println(i02==i02);
"D:\Program Files\Java\jdk1.8.0_45\bin\java"...
true
true
false
true
Process finished with exit code 0
Integer i01=59 的时候,会调用 Integer 的 valueOf 方法,
在这里的话,因为程序初次运行,没有 59 ,所以,直接创建了一个新的对象。
int i02=59 ,这是一个基本类型,存储在栈中。
Integer i03 =Integer.valueOf(59); 因为 IntegerCache 中已经存在此对象,所以,直接返回引用。
Integer i04 = new Integer(59) ;直接创建一个新的对象。
System. out .println(i01== i02); i01 是 Integer 对象, i02 是 int ,这里比较的不是地址,而是值。 Integer 会自动拆箱成 int ,然后进行值的比较。所以,为真。
System. out .println(i01== i03); 因为 i03 返回的是 i01 的引用,所以,为真。
System. out .println(i03==i04); 因为 i04 是重新创建的对象,所以 i03,i04 是指向不同的对象,因此比较结果为假。
System. out .println(i02== i04); 因为 i02 是基本类型,所以此时 i04 会自动拆箱,进行值比较,所以,结果为真。
相关文章推荐
- 使用fuel部署openstack时遇到的问题记录一下
- Java序列化之transient和serialVersionUID的使用
- UI元素状态伪类选择器
- 转 String,StringBuffer与StringBuilder的区别??
- Query 提交按钮置灰与恢复
- 小米手机 更新系统之后(MIUI 7.2稳定版) 拍照上传返回 取不到数据问题!
- PDE14 heat equation intuition
- Could not complete request java.lang.NullPointerException
- 虚幻UE4蓝图添加数学表达式
- 使用CSS3 Media Queries实现网页自适应
- java Integer.valueOf()方法
- UIScrollerView常见属性
- 《iOS Human Interface Guidelines》——Date Picker
- 如何知道自己设备的UUID
- UITabBarController简单介绍
- PDE7 wave equation: intuition
- 创建UIWindow
- APUE之线程初探
- Android Handler机制 (一个Thead中可以建立多个Hander,通过msg.target保证MessageQueue中的每个msg交由发送message的handler进行处理 ,但是
- 在Android子线程中初始化handler后,为什么该子线程也能更新UI?