integer类型与int的==比较
2018-03-25 17:17
267 查看
转自:https://www.cnblogs.com/tianwenmy/p/6431596.htmljava中有两种类型基本类型
基本数据类类型存的是数值本身引用类型
引用类型变量在内存放的是数据的引用基本类型通过==比较的是他们的值大小,而引用类型比较的是他们的引用地址
Integer f1 = Integer.valueOf(100);
Integer f2 = Integer.valueOf(100);
Integer f3 = Integer.valueOf(150);
Integer f4 = Integer.valueOf(150);
思考:那么Integer.valueOf()返回的Integer是不是是重新new Integer(num);来创建的呢?如果是这样的话,那么== 比较返回都是false,因为他们引用的堆地址不一样。具体来看看Integer.valueOf的源码
Integer b = 3; 自动调用Integer.valueOf(3) 返回一个Integer的对象。 这个对象存放到cache中的(上面一段代码分析)。 而 Integer a = new Integer(3);这里创建了一个新的对象Integer 所以 a == b 返回的是falsea == c 分析
一个Integer 与 int比较,先将Integer转换成int类型,再做值比较,所以返回的是true。参考资料:《探索java基本类型和包装类型的使用运算符==进行比较的底层细节》
分析:A: Integer 与 int 比较的时候将Integer转成int在比价两个值大小,所以排除
B: Integer i01 = 59;默认处理Integer i01 =Integer.valueOf(59); i01与 i03数值在-128 - 127之间,所以在cache缓存中获取Integer对象,他们引用地址是一样的。所以排除
C: i03获取的是cache中缓存好的的Integer地址,而i04是重新在堆中创建一个地址,所以两个地址是不一样的
D:A一样的原理。
基本数据类类型存的是数值本身引用类型
引用类型变量在内存放的是数据的引用基本类型通过==比较的是他们的值大小,而引用类型比较的是他们的引用地址
正文
在一些特殊的类中,如Integer在使用==比较的时候往往非常容易出错,下面通过几个例子来探索一下具体的原理代码片段public class Test03 { public static void main(String[] args) { Integer f1 = 100, f2 = 100, f3 = 150, f4 = 150; System. out.println( f1 == f2); //true System. out.println( f3 == f4); //false }}当我们给一个Integer赋予一个int类型的时候会调用Integer的静态方法valueOf。
Integer f1 = Integer.valueOf(100);
Integer f2 = Integer.valueOf(100);
Integer f3 = Integer.valueOf(150);
Integer f4 = Integer.valueOf(150);
思考:那么Integer.valueOf()返回的Integer是不是是重新new Integer(num);来创建的呢?如果是这样的话,那么== 比较返回都是false,因为他们引用的堆地址不一样。具体来看看Integer.valueOf的源码
public static Integer valueOf(int i) { if (i >= IntegerCache.low && i <= IntegerCache.high) return IntegerCache.cache[i + (-IntegerCache.low)]; return new Integer(i);}在IntegerCache中cache数组初始化如下,存入了-128 - 127的值
cache = new Integer[(high - low) + 1];int j = low;for( int k = 0; k < cache.length ; k ++) cache[k] = new Integer(j ++);从上面我们可以知道给Interger 赋予的int数值在-128 - 127的时候,直接从cache中获取,这些cache引用对Integer对象地址是不变的,但是不在这个范围内的数字,则new Integer(i) 这个地址是新的地址,不可能一样的代码片段
public static void main(String[] args) { Integer a = new Integer(3); Integer b = 3; int c = 3; System.out.println(a == b); System.out.println(a == c); }a == b分析
Integer b = 3; 自动调用Integer.valueOf(3) 返回一个Integer的对象。 这个对象存放到cache中的(上面一段代码分析)。 而 Integer a = new Integer(3);这里创建了一个新的对象Integer 所以 a == b 返回的是falsea == c 分析
一个Integer 与 int比较,先将Integer转换成int类型,再做值比较,所以返回的是true。参考资料:《探索java基本类型和包装类型的使用运算符==进行比较的底层细节》
延伸
java中还有与Integer类似的是Long,它也有一个缓存,在区间[-128,127]范围内获取缓存的值,而Long与long比较的时候先转换成long类型再做值的比较Double类型,它没有缓存,但是当Double与double比较的时候会先转换成double类型,再做值的比较一道牛客网的习题分析:A: Integer 与 int 比较的时候将Integer转成int在比价两个值大小,所以排除
B: Integer i01 = 59;默认处理Integer i01 =Integer.valueOf(59); i01与 i03数值在-128 - 127之间,所以在cache缓存中获取Integer对象,他们引用地址是一样的。所以排除
C: i03获取的是cache中缓存好的的Integer地址,而i04是重新在堆中创建一个地址,所以两个地址是不一样的
D:A一样的原理。
相关文章推荐
- Integer 类型与 int 的==比较
- Java中的Integer和int等包装类和基本数据类型简单比较
- Integer类型与int的==比较
- 关于Integer对象比较,和int基本类型比较的一些问题
- Java中Integer与int类型的比较--装箱和拆箱
- Integer与int类型之间的值比较,及相互转化
- Java中Integer与int类型的比较--装箱和拆箱
- Java自动装箱解箱问题&&int和Integer类型==比较问题
- Integer类型与int的==比较
- Integer类型与int的==比较
- Java Integer和int类型变量的两两相等性比较
- int 与 Integer 类型的比较
- Integer类型与int类型的==比较
- Integer 类型与 int 的==比较
- Java之Integer与int类型数据的比较-yellowcong
- Integer类型与int的==比较
- Integer和int基本类型的比较
- Integer和int大小比较
- Integer与int的种种比较你知道多少?
- JavaSE8基础 Integer.toString 将int类型转为同面值的String类型