一篇文章搞明白Integer、new Integer() 和 int 的概念与区别
基本概念的区分
1、Integer 是 int 的包装类,int 则是 java 的一种基本数据类型
2、Integer 变量必须实例化后才能使用,而int变量不需要
3、Integer 实际是对象的引用,当new一个 Integer时,实际上是生成一个指针指向此对象;而 int 则是直接存储数据值
4、Integer的默认值是null,int的默认值是0
Integer、new Integer() 和 int 的比较
1、两个 new Integer() 变量比较 ,永远是 false
因为new生成的是两个对象,其内存地址不同
Integer i = new Integer(100); Integer j = new Integer(100); System.out.print(i == j); //false
2、Integer变量 和 new Integer() 变量比较 ,永远为 false。
因为 Integer变量 指向的是 java 常量池 中的对象,而 new Integer() 的变量指向 堆中 新建的对象,两者在内存中的地址不同。
Integer i = new Integer(100); Integer j = 100; System.out.print(i == j); //false
3、两个Integer 变量比较,如果两个变量的值在区间-128到127 之间,则比较结果为true,如果两个变量的值不在此区间,则比较结果为 false 。
Integer i = 100; Integer j = 100; System.out.print(i == j); //true Integer i = 128; Integer j = 128; System.out.print(i == j); //false
分析:
Integer i = 100 在编译时,会翻译成为 Integer i = Integer.valueOf(100),而 java 对 Integer类型的 valueOf 的定义如下:
public static Integer valueOf(int i){ assert IntegerCache.high >= 127; if (i >= IntegerCache.low && i <= IntegerCache.high){ return IntegerCache.cache[i + (-IntegerCache.low)]; } return new Integer(i); }
java对于-128到127之间的数,会进行缓存。
所以 Integer i = 127 时,会将127进行缓存,下次再写Integer j = 127时,就会直接从缓存中取,就不会new了。
4、 int 变量 与 Integer、 new Integer() 比较时,只要两个的值是相等,则为true
因为包装类Integer 和 基本数据类型int 比较时,java会自动拆包装为int ,然后进行比较,实际上就变为两个int变量的比较。
Integer i = new Integer(100); //自动拆箱为 int i=100; 此时,相当于两个int的比较 int j = 100; System.out.print(i == j); //true
示例1:
public class IntegerDemo { public static void main(String[] args) { int i = 128; Integer i2 = 128; Integer i3 = new Integer(128); System.out.println("i == i2 = " + (i == i2)); // Integer会自动拆箱为int,所以为true System.out.println("i == i3 = " + (i == i3)); // true,理由同上 Integer i4 = 127;// 编译时被翻译成:Integer i4 = Integer.valueOf(127); Integer i5 = 127; System.out.println("i4 == i5 = " + (i4 == i5));// true Integer i6 = 128; Integer i7 = 128; System.out.println("i6 == i7 = " + (i6 == i7));// false Integer i8 = new Integer(127); System.out.println("i5 == i8 = " + (i5 == i8)); // false Integer i9 = new Integer(128); Integer i10 = new Integer(128); System.out.println("i9 == i10 = " + (i9 == i10)); // false } }
答案是
i == i2 = true i == i3 = true i4 == i5 = true i6 == i7 = false i5 == i8 = false i9 == i10 = false
示例2:
package demo1.demo1; public class Campare { public static void main(String[] args) { Integer a = new Integer(127), b = new Integer(128); int c = 127, d = 128, dd = 128; Integer e = 127, ee = 127, f = 128, ff = 128; System.out.println(a == b); // false 因为a,b都是new出来的对象,地址不同所以为false System.out.println(a == c); // true a会自动拆箱为int类型 System.out.println(a == e); // false 指向的地址不同a是new出来的 System.out.println(e == c); // true e会自动拆箱为int类型 System.out.println(e == ee);// true Integer对 处于-128到127范围之间,指向了同一片地址区域 System.out.println(b == f); // false 指向的地址不同b是new出来的 System.out.println(f == d); // true f自动拆箱为int类型 System.out.println(f == ff); /* * false 指向的不是同一片地址区域。 * 在Integer类型中,-128到127存放的是同一片区域地址, * 之外的数是另外开辟空间来进行 存储的 */ System.out.println(d == dd); // true 不解释 } }
示例3:
Integer i01 = 59; int i02 = 59; Integer i03 =Integer.valueOf(59); Integer i04 = new Integer(59);
以下输出结果为false的是:
System.out.println(i01== i02); System.out.println(i01== i03); System.out.println(i03== i04); System.out.println(i02== i04);
解析:
i01 == i02 。i01.intValue()i02 两个值的比较5959 -->true;
i01 == i03 。由于 59在-128到127之间,所以,i01和i03的赋值操作返回的是同一个对象。都是从chche中返回的同一个对象,对象地址相同 true;
i03 == i04。i03是来自缓存值,i04是新new的对象 ,二者不是同一个对象,所以false。
i02 == i04。和第一个类似,true。
答案是 C 。
示例4:
与示例3的唯一不同,就是将值全部改成128。
Integer i01 = 128; int i02 = 128; Integer i03 = Integer.valueOf(128); Integer i04 = new Integer(128);
以下输出结果为false的是:
System.out.println(i01 == i02); System.out.println(i01 == i03); System.out.println(i03 == i04); System.out.println(i02 == i04);
答案:
true false false true
最后
欢迎大家一起交流,喜欢文章记得点个赞哟,感谢支持!
低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
Java虚拟机之内存区域,今天这篇文章来深入理解一下把
Java虚拟机之内存区域,今天这篇文章来深入理解一下把 深入理解Java虚拟机之Java内存区域 Java 虚拟机在执行 Java 程序的时候会把它所管理的内存分为多个不同的区域,每个区域都有不同的作用,以及由各自的生命周期,有些随着虚拟机进行的 启动而存在,有些区域则依赖于用户线程的启动或结束而建立或销毁等。在《Java虚拟机规范(Java SE7版)》中规定,Java 内存分为以下一种,如图所示: 1、程序计数器 程序计数器(Program Counter Register)是一个内存较小的区域,它可以被看作是当前线程所执行到的字节码的行号的指示器,字节码解释器在执行下一条指令,比如分支,跳转,循环,异常处理等都需要依赖这个计数器来完成的。 由于 Java 多线程是通过不断的切换分配处理器时间片的方式来实现的,在任何一个确定的时刻,一个处理器都只会执行一条指令。也就是说,在多线程中每个线程都可以抢到 cpu 的时间片,那么别抢去的线程会立即停止下来,直到它再一次获得 cpu 的时间片。那么, Java 虚拟机是如何确保再一次获得处理器时间片的时候能够在正确的位置上继续执行指令? J...
- 下一篇
SpringBoot2.0 整合 Swagger2 ,构建接口管理界面
一、Swagger2简介 1、Swagger2优点 整合到Spring Boot中,构建强大RESTful API文档。省去接口文档管理工作,修改代码,自动更新,Swagger2也提供了强大的页面测试功能来调试RESTful API。 2、Swagger2常用注解 Api:修饰整个类,描述Controller的作用 ApiOperation:描述一个类的一个方法,或者说一个接口 ApiParam:单个参数描述 ApiModel:用对象来接收参数 ApiProperty:用对象接收参数时,描述对象的一个字段 ApiResponse:HTTP响应其中1个描述 ApiResponses:HTTP响应整体描述 ApiIgnore:使用该注解忽略这个API ApiError :发生错误返回的信息 ApiImplicitParam:一个请求参数 ApiImplicitParams:多个请求参数 二、与SpringBoot2.0 整合 1、核心依赖 spring-boot:2.1.3.RELEASE swagger:2.6.1 2、Swagger2 配置 import org.springframe...
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
-
Docker使用Oracle官方镜像安装(12C,18C,19C)
- Springboot2将连接池hikari替换为druid,体验最强大的数据库连接池
- CentOS8编译安装MySQL8.0.19
- Docker快速安装Oracle11G,搭建oracle11g学习环境
- SpringBoot2配置默认Tomcat设置,开启更多高级功能
- MySQL8.0.19开启GTID主从同步CentOS8
- CentOS7,8上快速安装Gitea,搭建Git服务器
- Jdk安装(Linux,MacOS,Windows),包含三大操作系统的最全安装
- SpringBoot2编写第一个Controller,响应你的http请求并返回结果
推荐阅读
最新文章
- Springboot2将连接池hikari替换为druid,体验最强大的数据库连接池
- Docker使用Oracle官方镜像安装(12C,18C,19C)
- CentOS6,CentOS7官方镜像安装Oracle11G
- SpringBoot2整合Redis,开启缓存,提高访问速度
- Jdk安装(Linux,MacOS,Windows),包含三大操作系统的最全安装
- SpringBoot2配置默认Tomcat设置,开启更多高级功能
- SpringBoot2整合MyBatis,连接MySql数据库做增删改查操作
- Hadoop3单机部署,实现最简伪集群
- MySQL8.0.19开启GTID主从同步CentOS8
- SpringBoot2编写第一个Controller,响应你的http请求并返回结果