Integer a=100,b=200比较详解
题记:
前几天面试Java基础给来了个面试题Integer a=200,b=200;System.out.println(a==b);当时回答是false,后来面试官又来了一个Integer a=100,b=100;System.out.println(a==b);这个回答的也是false当时面试官笑笑说恭喜你回答错误,当时一愣回来才想起int的范围,特做此笔记以做记录;
补充:
Java如何查看对象的内存地址?Java是使用hashcode来表示对象的内存地址,两个相同的对象的hashcode是相同的,我们可以使用System.identityHashCode(传输进去的参数是一个对象)打印对象的hashcode值。
分析:
我们都知道基本类型通过==比较的是他们的值大小,而引用类型比较的是他们的引用地址
这里肯定你也会和我有一样的疑问为什么200的时候是false,100的时候是true,应该Integer包装对象都是比较的应该是内存的地址都应该是false才对啊!这里请看源码:
当我们给一个Integer赋予一个int类型的时候会调用Integer的静态方法valueOf。
由源码我们可以看到Integer的范围是“-128~127”,当i在这个范围内是从IntegerCache中直接获取,当超越这个范围才会new 一个新的Integer对象
@Test public void testInteger(){ Integer i1 = 100; Integer i2 = 100; Integer i3 = 200; Integer i4 = 200; System.out.println(i1==i2); System.out.println(i3==i4); }
输出结果:
true false
这里有一点需要解释:
一个Integer 与 int比较,先将Integer转换成int类型,再做值比较,所以返回的是true。
java中还有与Integer类似的是Long,它也有一个缓存,在区间[-128,127]范围内获取缓存的值,而Long与long比较的时候先转换成long类型再做值的比较
Double类型,它没有缓存,但是当Double与double比较的时候会先转换成double类型,再做值的比较
原文链接: https://www.yukx.com/hangshuo/article/details/2356.html 优科学习网Integer a=100,b=200比较详解
-
Halfmessage是在消息队列(MessageQueue,MQ)领域,尤其是阿里巴巴开源的消息中间件RocketMQ中提到的一个术语,它特指一种特殊的事务消息状态。在分布式事务处理的上下文中,半消息(HalfMessage)指的是那些已被生产者成功发送到消息队列服务器,但由于生产者尚未完成本地事
-
可靠消息服务方案是一种用于确保在分布式系统中实现消息传递最终一致性的技术方案。在分布式事务处理中,尤其是在微服务架构或者分布式系统架构下,不同服务之间需要通过异步消息通信来协调事务,而直接使用传统的ACID事务往往难以满足高并发、高性能的需求。可靠消息服务(ReliableMessageServic
-
TCC(Try-Confirm-Cancel)是一种分布式事务解决方案,该方案由分布式事务协调专家LeslieLamport提出,并在实践中逐渐演化和发展。TCC模式常用于微服务架构下的分布式事务场景,它的核心思想是在每个参与分布式事务的服务中实现三个阶段的操作:Try阶段:这个阶段是尝试阶段,服务
-
对于Java资深工程师的面试,面试官通常会期望候选人能深入理解Java的核心概念、设计模式、框架原理、并发编程、JVM优化、以及实际项目中的最佳实践等方面的知识。以下是一些可能会被问到的资深Java面试题示例:Java基础部分Java内存模型(JMM)是如何工作的?解释Java中的内存泄漏,并给出具
-
1、Goroutine定义 Golang在语言级别支持协程,称之为Goroutine。Golang标准库提供的所有系统调用操作(包括所有的同步I/O操作),都会出让CPU给其他Goroutine。这让Goroutine的切换管理不依赖于系统的线程和进程,也不依赖于CPU的核心数量,而是交给Golan
-
Go基础面试题1、与其他语言相比,使用Go有什么好处?与其他作为学术实验开始的语言不同,Go代码的设计是务实的。每个功能和语法决策都旨在让程序员的生活更轻松。Golang针对并发进行了优化,并且在规模上运行良好。由于单一的标准代码格式,Golang通常被认为比其他语言更具可读性。自动垃圾收集明显比J