equals和==的区别

标签: javaSe基础  java

==比较的是堆内存中的地址是否相同

     String s1 ="aaa";
     String s2 ="aaa;
     System.out.println(s1==s2);//true

s1和s2是对象的引用存放在栈中,首先s1创建在栈中,在堆中会寻找是否有aaa的,如果没有就把aaa放入常量池中,其次s2对象引用也存放在栈中,也去常量池中寻找是否有aaa,如果有直接指向,所以s1和s2指向的是一个常量池的内存地址,而==比较就是堆的内存地址,所以结果为ture

equals本质上比较引用对象的地址本质上就是==
比较的是内存堆中的地址
在这里插入图片描述
String重写的equals方法,我们来看下String类的equals方法:
在这里插入图片描述
首先判断是否是String类型
获取原本String类型的长度
如果原本String类型长度等于比较String的类型长度
分别用2个字符数组存放
用while以此重第一个字符开始比较如果不等返回false
比较完没有发现不同,返回true

总结:如果类没有重写equals方法,那么equals等于==
如果重写了,equals将依次比较每个字符的值

来一组==来判断下String类型

    String s1 = new String("zs");
	String s2 = new String("zs");
	//==比较的是引用的堆的对象是否相等 图中2个对象创建了2个不一样的堆 false
	System.out.println(s1 == s2); //false
	String s3 = "zs";``
	String s4 = "zs";
	//==比较的是引用堆的对象是否相同 
	System.out.println(s3 == s4);  //true
	
	System.out.println(s3 == s1); //false
	
	String s5 = "zszs";
	//字符串是一个不可变的对象,当我们创建新的对象的时候 会使用新的方法new进行创建
	//s3 s4是字符串变量,其指向的对象可以改变,程序在编译期就不能完全确定其值,
	//故变量参与拼接形成的字符串放入堆中
	String s6 = s3+s4;
	System.out.println(s5 == s6);//内容一样  引用的堆是不一样的 一个引用的是常量池,一个引用的是堆   所以是false
	final String s7 = "zs";
	final String s8 = "zs";
	//final修饰的对象是常量,因为都是常量在编译前就确定,由编译器优化
	//在编译期就将+两边合并了,直接合并成一个常量"zszs"故引用一个,常量池的内容是可以共享的
	String s9 = s7 + s8;
	System.out.println(s5 == s9);//true
	
	//s3 s4是字符串变量,其指向的对象可以改变,程序在编译期就不能完全确定其值,故变量参与拼接形成的字符串放入堆中
	//s5指向的是常量池的引用
	final String s10 = s3+s4;
	System.out.println(s5 == s10);//false
	****

在这里插入图片描述
字符串常量相加,不会用到StringBuilder对象,有一点要注意的是:字符串常量和字符串是不同的概念,字符串常量储存于方法区,而字符串储存于堆(heap)。

对于字符串:其对象的医用都是存储在栈中,如果是编译期就创建好(直接用双引号定义的)就存储在常量池中,如果是运行期间(new出来的)才能确定就存储在堆中。对于eques相等的字符串,常量池用于只有一份,在堆中有多份

版权声明:本文为a1499356751原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/a1499356751/article/details/108002303

智能推荐

CentOS 7配置南大docker镜像

文章目录 CentOS 7配置南大docker镜像 0.帮助页面 1.系统要求 2.卸载旧版本(没有旧版本可跳过) 3.安装方式 4.准备工作 5.可选操作 Stable Test Nightly 6.安装docker引擎 7. (可选)修改配置文件防止与xshell连接冲突 8.启动docker CentOS 7配置南大docker镜像 0.帮助页面 南大docker源:https://mirr...

Qcon演讲纪实:详解如何在实时视频通话中实现AR功能

2018年4月20日-22日,由 infoQ 主办的 Qcon 2018全球软件开发大会在北京如期举行。声网首席 iOS 研发工程师,iOS 端移动应用产品设计和技术架构负责人龚宇华,受邀分享了《基于 ARkit 和 ARcore,在实时视频通话中实现 AR 功能》,在演讲中剖析了 AR 与 VR 差异,ARKit 的工作原理,以及逐步讲解如何基于 ARKit 与声网Agora SDK 创建 AR...

POJ2348 UVa10368 HDU1525 Euclid's Game【博弈】

Euclid's GameTime Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total Submission(s): 4106    Accepted Submission(s): 1947 Probl...

使用Breeze.js编写更好的查询

这篇文章是由同行评审Agbonghama柯林斯 。 感谢所有SitePoint的审稿作出SitePoint内容也可以是最好的! 数据量正在迅速发展,他们正在变得越来越复杂,维护。 许多开发人员希望避免由数据问题他们的工作过程中造成的问题和头痛。 一个使我们的工作更轻松的图书馆是Breeze.js 。 在这篇文章中,我们将讨论我们如何能够写出更好的查询与Breeze.js。 但是首先,我们应该知道什...

Netty框架构建Nio编程

~~~ 随手点赞,养成习惯 ~~~ 为什么选择Netty框架 Netty是业界最流行的NIO框架之一,它的健壮性、功能、性能、可定制性和可扩展性在同类框架中都是首屈一指的。 优点: ① API使用简单,开发门槛低 ②功能强大,预置了多种编解码功能,支持多种主流协议 ③ 定制能力强,可以通过ChannelHandler对通信框架进行灵活地扩展; ④性能高,通过与其他业界主流的NIO框架对比,Nett...

猜你喜欢

【JZOJ5262】【GDOI2018模拟8.12】树(DP,性质题)

Description Solution 首先我们可以知道两个性质:1、路径u-v和路径v-w可以合并为路径u-w;2、路径u1-v1加路径u2-v2和路径u1-v2加路径u2-v1是等价的(就是起始点和终点可以互换) 那么知道这些性质之后就很好做了。我们只用知道每个点多少次做起点和多少次做终点。 我们设f[i]表示满足i子树的需求i上的值要是多少。 那么枚举i的所有儿子,判断a[i]-f[i],...

【String-easy】541. Reverse String II 反转的元素,有反转个数和间隔

1. 题目原址 https://leetcode.com/problems/reverse-string-ii/ 2. 题目描述 3. 题目大意 给定一个字符串,和字符串的间隔k, 这个k表示每k个数反转一次,然后再间隔k个元素再反转k个元素。 4. 解题思路 只要按照间隔去反转就可以了。然后间隔k个元素不反转是通过让i每次递增 2*k完成的。 5. AC代码 6. 相似题型 【1】344. Re...

【C语言笔记结构体】

我们都知道C语言中变量的类型决定了变量存储占用的空间。当我们要使用一个变量保存年龄时可以将其声明为int类型,当我们要使用一个变量保存某一科目的考试成绩时可以将其声明为float。 那么,当我们要做一个学生信息管理系统时,需要保存学生的姓名、学号、年龄等信息,该怎么做呢? 如当要保存三个学生的信息时, 方法一是: 方法二是: 显然,方法二跟更清晰,因为它把name、num、age都集成在一个模板,...

39. Combination Sum 回溯算法简析

LeetCode传送门     这道题要求给你一组正数 C,然后给你一个目标数 T,让你从那组C中找到加在一起等于 T 的那些组合。     例如:给你 [2,3,6,7] 和 7,则返回 [[2,2,3],[7] ] 。      想解决这个问题前,我们首先引入一个新问题,图(树)的遍历问题。  ...

git安装|Linux系统安装 git|Linux如何安装git?Linux通过远程安装git|

Git是一个开源的分布式版本控制系统,可以有效、高速地处理项目版本管理。Git 是 Linus Torvalds 为了帮助管理 Linux 内核开发而开发的一个开放源码的版本控制软件。 开发者需要一个GIT账号,通过这个查看项目的提交记录,可以更加清楚项目的开发情况,便于版本控制。 以下介绍在CentOS8操作系统搭建GIT服务器。   一、安装GIT服务器流程   安装GIT...