“==”和“equals”有的时候和你想象的不一样

大家都知道用“==”对两个对象进行比较时,比较的是他们两个的地址。而“equals”在比较的时候比较的时候比较的是他们两个的值。

但是今天我就给你们讲一点刷新三观的东西。
		StringBuffer a=new StringBuffer("a");
        StringBuffer b=new StringBuffer("a");
        System.out.println(a==b);//false
        System.out.println(a.equals(b));//false
        String c=new String("a");
        String d=new String("a");
        System.out.println(c==d);//false
        System.out.println(c.equals(d));//true

如果我们new一个对象那么内存中会给它分配地址的,所以只要是我们new出来的对象比较他们的地址那么得到结果就是false,但是equals比较的是值,那为什么a.equals(b)得到的结果是false,而c.equals(d)得到的是true?

这就需我们看一下源码和jdk
String的包下重写了equals的方法

在这里插入图片描述
在这里插入图片描述
这是String下中equals的源码
在这里插入图片描述

String包下的没有重写equals方法只是从objec那里继承来了equals方法

在这里插入图片描述
在这里插入图片描述
因为在StringBuffer中没有重写equals的方法所以它比较的还是两个对象的地址,但String中将从父类中继承来的equals方法重写,重写后比较的就是两个对象的值。

大家在看看这一段代码
		class Demo1{}
		
		Demo1 a=new Demo1();
        Demo1 b=new Demo1();
        System.out.println(a.equals(b));//false
        System.out.println(a==b);//false
        a=b;
        System.out.println(a.equals(b));//true
        System.out.println(a==b);//true

对于非字符串变量,在用“==”和“equals”是比较的都是他们存在堆内存中的首地址,所以前两次打印出的是false,让a指向b的地址后打印出来的就是两个true。

[1]https://wenku.baidu.com/view/008b31e2f12d2af90342e667.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值