黑马程序员技术交流社区

标题: 关于Integer [打印本页]

作者: 杨雯雯    时间: 2012-12-20 12:53
标题: 关于Integer
本帖最后由 杨雯雯 于 2012-12-22 10:24 编辑

public class a{   
public static void main(String[] args){

        Integer v1=100;

        Integer v2=100;

          System.out.println(v1==v2);  //输出:true

        Integer w1=200;

        Integer w2=200;

          System.out.println(w1==w2);  //输出:false

    }

}
两结果不同,为啥,详细点
作者: 黄锦成    时间: 2012-12-20 13:14
这是享元模式,在-128~127之间,都是共享对象的,不在这范围内,则不能共享。在老张的高新技术那里有讲到
作者: 臧盼    时间: 2012-12-20 13:18
因为v1和v2取值在-128-127之间,而且i1和i2指向的是同一个Integer对象,这样在JDK1.5以后出现的新特性中,当数值在byte范围之内如果该数值已经存在,就不会再在内存中开辟新空间,那么v1和v2是相同的地址,所以为true。w1和w2的值超过了byte的范围,所以w1和w2各自都有自己的空间,具有不同的地址,所以为false。
作者: 刘学宾    时间: 2012-12-20 13:21
在java中,如果Integer包装的数值在一个字节内(-128~127),
在内存空间只存在一份数值,不会开辟新的空间,节省内存空间,
所以v1和v2指向同一个Integer对象。  为true
而w1和w2的数值超出了一个字节,会开辟两个内存空间,即
创建两个Inetger对象,所以  输出为false。
作者: 高境    时间: 2012-12-20 13:30
本帖最后由 高境 于 2012-12-20 13:31 编辑

第一个为true是因为v1和v2指向了同一个Integer对象,因为当数值在byte范围内,对于新特性,如果该数值已经存在,则不会开辟新的空间。而第二个为false是因为w1和w2不是指向同一个对象。

Integer与Integer间的比较,自动装箱过程,超过范围则创建新对象。JVM会自动维护八种基本类型的常量池,int常量池中初始化-128~127的范围,所以当为Integer i=127时,在自动装箱过程中是取自常量池中的数值,而当Integer i=128时,128不在常量池范围内,所以在自动装箱过程中需new 128,所以地址不一样。


还有你的java程序不规范,你的class类名是a。你觉得这样有意义么?
作者: 杨雯雯    时间: 2012-12-20 13:33
高境 发表于 2012-12-20 13:30
第一个为true是因为v1和v2指向了同一个Integer对象,因为当数值在byte范围内,对于新特性,如果该数值已经 ...

嗯,我知道了,以后会注意了
作者: 黄嵘才    时间: 2012-12-20 13:34
API里头这样讲:
Integer 类在对象中包装了一个基本类型 int 的值。Integer 类型的对象包含一个 int 类型的字段。
我说:
当数值大小处于-128~127时,会指向int基本数据类型,直接保存的数据。v1和v2都是100.即
Integer v1=100;Integer v2=100;
同于:int v1=100;int v2=100;
当大于这个范围:就相当new出了两个Integer对象。v1,v2分别存入的地址是不同,所以比较不等。
具体是怎么实现的,请楼下。




欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) 黑马程序员IT技术论坛 X3.2