java中int和Integer的区别

本文详细探讨了Java中Integer与int类型的相等性判断原则,包括不同情况下Integer对象间的比较逻辑以及Integer与int之间的自动装箱与拆箱过程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

百度了一下,这是别人对这个问题的理解:

关于判断int和Integer生成的数据是否相等:
  ①无论如何,Integer与new Integer不会相等。不会经历拆箱过程,后者的引用指向堆,而前者指向专门存放他的内存(常量池),他们的内存地址不一样,所以为false
  ②两个都是非new出来的Integer,如果数在-128到127之间,则是true,否则为false
  java在编译Integer i2 = 128的时候,被翻译成-> Integer i2 = Integer.valueOf(128);而valueOf()函数会对-128到127之间的数进行缓存
  ③两个都是new出来的,都为false
  ④int和integer(无论new否)比,都为true,因为会把Integer自动拆箱为int再去比

以上是别人对这两个类型在进行==比较时候问题的总结,下面是我自己的一些理解:

对于①:

Integer i1 = 1;

Integer i2 = new Integer(1);

i1==i2;//false 因为i1指向堆 i2指向常量池 内存地址不等


对于②:

Integer i1 = 1;

Integer i2 = 1;

i1==i2;//true

Integer i3 = 128;

Integer i4 = 128;

i3==i4;//false 因为在编译Integer i3 = A; A是一个常数的时候,会翻译成:Integer i3 = Integer.valueOf(A); 而valueOf()函数会对-128到127及其之间的数进行缓存,所以当A大于等于-128 小于等于127的时候,为true,超出这个范围为false


对于③:

Integer i1 = new Integer(1);

Integer i2 = new Integer(1);

i1==i2;//false new出来的堆地址不一样


对于④:

Integer i1 == new Integer(1);

Integer i2 == 1;

int i3 == 1;

i1==i3;//true

i2==i3;//true 因为无论Integer是直接等于整型还是使用new关键字创建 在比较的时候都会将Integer进行拆箱为int型进行比较。


最后说明一下所谓的拆箱和包箱:

包箱:将一个int常量赋值给Integer类,虚拟机调用valueOf方法包装它,将int变成一个Integer型,即“包箱"。如果这个int常量在-128到127之间,则这个int型常量对应的多个Integer对象实际上是同一个。

拆箱:用Integer类做算术运算,虚拟机会调用intValue拆开它将Integer变成一个int常量,即“拆箱”。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值