Java5在自动装箱时使用“==”会遇到什么问题?

ImportNew注:本文由陈佳伟  翻译并投稿到ImportNew。感谢陈佳伟!欢迎其他朋友通过这里投递文章

在一些JVM的封装类缓存对象中, 例如Integer,在范围-128 到127之间如果通过“==”进行比较得到的返回值是true的话,那么他们返回的就是相同的对象,但是在这个范围之外就不行了。更糟的是这种行为更多依赖于JVM。因此检查时最好是用equals()方法而避免使用“==”。

例如:

Integer i1 = 260;
Integer i2 = 260;

if (i1 == i2) 
System.out.println("i1 and i2 is equal");
else 
System.out.println("i1 and i2 is not equal ");

你会得到”i1 and i2 is not equal “这个结果,至少在我的机器上是这样得。因为在这个例子中,解封装操作并没有参与。“260”这个字面值被封装在两个不同的整型对象(不同的JVM结果可能不一样),然后这些对象通过“==”进行比较,结果是false,因为这两个对象是不同的实例,拥有不同的内存地址,因为在==表达式的两边都是对象并没有解封装的操作。

Integer i1 = 100;
Integer i2 = 100;

if (i1 == i2) 
System.out.println("i1 and i2 is equal");
else 
System.out.println("i1 and i2 is not equal ");

运行这里的代码你会得到”i1 and i2 is equal”这个结果。

因为int的值在-127到127这个范围内JVM会将值缓存起来,因此i1和i2,虚拟机确确实实使用了相同的对象实例(内存地址相同),所以“==”会返回true的结果。

以上所说并非绝对,因为有些JVM在一些具体的interger值上进行了优化并尝试每次返回相同的对象,但是这不是有保证的行为。
原文链接: javarevisited 翻译: ImportNew.com - 陈家伟
译文链接: http://www.importnew.com/6997.html
[ 转载请保留原文出处、译者和译文链接。]



相关文章

发表评论

Comment form

(*) 表示必填项

3 条评论

  1. ethan 说道:

    在申明对象时都是Integer,比较方式肯定要用equals方法了。只有其中一个变量被申明为int,才会被拆箱int,从而可以用==比较。比如:int a=1;Integer b=1;当if (a==b)时是能得到正确行为的。不确定时可以编译代码

    Thumb up 0 Thumb down 0

  2. qu 说道:

    看下 设计模式之 享元模式

    Thumb up 0 Thumb down 0

  3. 魔神翼 说道:

    因为int的值在-128到127这个范围内JVM会将值缓存起来

    Thumb up 0 Thumb down 0

跳到底部
返回顶部