Java中==和equals()的区别

 在Java学习和面试中经常遇到这个问题,虽然简单,但是值得深究一下。

一、对于基本数据类型

先看一下下面的代码:

int a = 123;
int b = 123;
System.out.println(a == b);//结果为:true

String s1 = "123";
String s2 = "123";

System.out.println(s1 == s2);//结果为:true

String s3 = new String("123");
System.out.println(s1 == s3);//结果为:false

 最终结果是 true,true,false,那既然==是比较的地址,那么int数据的地址是怎样的呢,String又是怎样的呢?

 对于基本数据类型(byte,short,char,int,float,double,long,boolean)来说,他们是作为常量在方法区中的常量池里面以HashSet策略存储起来的,对于这样的字符串 “123” 也是相同的道理,在常量池中,一个常量只会对应一个地址,因此不管是再多的 123,“123” 这样的数据都只会存储一个地址,所以所有他们的引用都是指向的同一块地址,因此基本数据类型和String常量是可以直接通过==来直接比较的。

二、对于基本数据的包装类型

 另外,对于基本数据的包装类型(Byte, Short, Character,Integer,Float, Double,Long, Boolean)除了Float和Double之外,其他的六种都是实现了常量池的,因此对于这些数据类型而言,一般我们也可以直接通过==来判断是否相等。那么再出一个问题考考大家

Integer i1 = 127;
Integer i2 = 127;
System.out.println(i1 = i2);//结果为:true

Integer m = 128;
Integer n = 128;
System.out.println(m == n);//结果为:false

 猜猜看,结果是啥?。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。

 结果是 true,false。没想到吧!其实是因为 Integer 在常量池中的存储范围为[-128,127],127在这范围内,因此是直接存储于常量池的,而128不在这范围内,所以会在堆内存中创建一个新的对象来保存这个值,所以m,n分别指向了两个不同的对象地址,故而导致了不相等。

三、equals()方法

 之前在网上也搜了很多相关的问题,但给出的答案却不尽人意,很多网友都说equals比较的是对象的内容,这样的说法是不准确的。首先我们来看看源码在Object类中定义的equals方法。

在这里插入图片描述
 可以看到,在Object类型的equals方法是直接通过来比较的,和是没有任何区别的。那么为什么又要说equlas和==的区别呢?是因为equals方法是可以由我们自己重写的。
&emqe;众所周知,我们所有的类都直接或间接地继承自java.lang.Object类,因此我们可以通过重写equals方法来实现我们自己想要的比较方法。来看看eclipse为我们自动生成的equals方法如下所示:
在这里插入图片描述
 可以看出,eclipse还是很智能的,它首先是判断两个对象的地址是否相等,若不相等再进行下面的成员变量判断。
 但这个方法体是完全可以由我们自己实现的,即便是我们直接 return true 都是可以的,只要能满足我们的业务需求,怎样写都是无所谓的,因此,equals比较的并不一定是对象的内容,它还可以由其他的信息来指导比较。

四、Sting的equals()方法

 源码如下图所示:
在这里插入图片描述
 可以看到,String的equals()方法,首先是比较对象地址是否相同,相同则返回true;不相同,依次比较俩对象的字符是否相等。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值