废话不多说了,直接给大家贴代码,具体代码如下所示:
java" id="highlighter_752718">
1
2
3
4
5
6
7
8
9
10
11
|
package com.test;
public class Test {
public static void main(String []args) {
Integer a = 100 ; //此处若使用new,则==值必为false
Integer b = 100 ;
System.out.println(a==b); //true
Integer c = 150 ;
Integer d = 150 ;
System.out.println(c==d); //false
}
}
|
这是什么原因呢?
1。java在编译的时候 Integer a = 100; 被翻译成-> Integer a = Integer.valueOf(100);
2。比较的时候仍然是对象的比较
3。在jdk源码中
1
2
3
4
5
6
7
|
public static Integer valueOf( int i) {
final int offset = 128 ;
if (i >= - 128 && i <= 127 ) { // must cache
return IntegerCache.cache[i + offset]; //符合值范围时候,进入也创建好的静态IntergerCache,i+offset的值表示去取cache数组中那个下标的值
}
return new Integer(i); //当不符合-128 127值范围时候。记住用的:new,开辟新的内存空间,不属于IntergerCache管理区
}
|
而
1
2
3
4
5
6
7
8
|
private static class IntegerCache {
private IntegerCache(){}
static final Integer cache[] = new Integer[-(- 128 ) + 127 + 1 ]; //开辟-128到127的内存区。有0的位置哦
static {
for ( int i = 0 ; i < cache.length; i++)
cache[i] = new Integer(i - 128 ); //为内存区的数组每个对象赋值
}
}
|
这边是java为了提高效率,初始化了-128--127之间的整数对象,所以在赋值在这个范围内都是同一个对象。
再加一句
1
2
3
4
5
6
7
8
9
|
Integer a = 100 ;
a++;
//这边a++是新创建了一个对象,不是以前的对象。
public static void main(String []args) {
Integer a = 100 ;
Integer b = a; //此时b指针指向值为100的堆地址 即a的堆地址,a==b成立
a++; //此时a指向的值发生变化为101,a指针指向101的堆地址。而b任然指向100
System.out.println(a==b); //false
}
|
总结
以上所述是小编给大家介绍的JAVA中Integer值的范围实例代码,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对服务器之家网站的支持!
原文链接:http://www.cnblogs.com/alternative/archive/2017/09/08/7494869.html