java中 == 與 equal 的區(qū)別講解
廢話不多說(shuō)了,開門見山吧,先來(lái)看一段代碼:
String str1 = new String("str");
String str2 = new String("str");
System.out.println("==比較 :"+ str1 == str2);
System.out.println("equal比較:"+ str1.equals(str2));
String str3 = "str1";
String str4 = "str1";
System.out.println("==比較 :"+ str3 == str4);
System.out.println("equal比較:"+ str3.equals(str4));
輸出的答案:

根據(jù)打印的可以發(fā)現(xiàn)使用equal比較時(shí)無(wú)論是使用自動(dòng)裝箱來(lái)實(shí)例化還是用new來(lái)實(shí)例化,返回的都true,而用==則不一樣了,自動(dòng)裝箱來(lái)實(shí)例化的返回的是true,而用new來(lái)
實(shí)例化的返回的確實(shí)false;先不急著解決為什么,先來(lái)了解下equals和==的區(qū)別,到時(shí)候就可以知道答案了
equals方法最初是在所有類的基類Object中進(jìn)行定義的,源碼是
public boolean equals(Object obj) {
return (this == obj);
}
可以看出這里定義的equals與==是等效的,但上面的怎么還會(huì)不一樣呢?
原因就是String類對(duì)equals進(jìn)行了重寫:
public boolean equals(Object anObject) {
if (this == anObject) {
return true;
}
if (anObject instanceof String) {
String anotherString = (String)anObject;
int n = count;
if (n == anotherString.count) {
char v1[] = value;
char v2[] = anotherString.value;
int i = offset;
int j = anotherString.offset;
while (n-- != 0) {
if (v1[i++] != v2[j++])
return false;
}
return true;
}
}
return false;
}
這里對(duì)equals重新需要注意五點(diǎn):
1 自反性:對(duì)任意引用值X,x.equals(x)的返回值一定為true.
2 對(duì)稱性:對(duì)于任何引用值x,y,當(dāng)且僅當(dāng)y.equals(x)返回值為true時(shí),x.equals(y)的返回值一定為true;
3 傳遞性:如果x.equals(y)=true, y.equals(z)=true,則x.equals(z)=true
4 一致性:如果參與比較的對(duì)象沒(méi)任何改變,則對(duì)象比較的結(jié)果也不應(yīng)該有任何改變
5 非空性:任何非空的引用值X,x.equals(null)的返回值一定為false
經(jīng)過(guò)重寫后就跟==有本質(zhì)的區(qū)別了:
equal:是用來(lái)比較兩個(gè)對(duì)象內(nèi)部的內(nèi)容是否相等的,由于所有的類都是繼承自java.lang.Object類的,所以如果沒(méi)有對(duì)該方法進(jìn)行覆蓋的話,調(diào)用
的仍然是Object類中的方法,而Object中的equal方法返回的卻是==的判斷,因此,如果在沒(méi)有進(jìn)行該方法的覆蓋后,調(diào)用該方法是沒(méi)有
任何意義的。在java面向?qū)ο蟮奶幚碇形覀円话阍趈avabean中都要選擇重寫equals方法,使用hibernate后,我們要生成數(shù)據(jù)庫(kù)的映射文件與實(shí)體
類,這是我們就最好在實(shí)體類中進(jìn)行equals方法的重寫,重寫時(shí)我們可以根據(jù)自己的定義來(lái)實(shí)現(xiàn)該方法只要遵守那五條原則,例如對(duì)于一個(gè)student類
我們定義只要在學(xué)號(hào)相同時(shí)我們就認(rèn)為這兩個(gè)對(duì)象時(shí)相等的;同時(shí)我們還要重寫hashcode方法http://www.dhdzp.com/article/42408.htm
==:是用來(lái)判斷兩個(gè)對(duì)象的地址是否相同,即是否是指相同一個(gè)對(duì)象。比較的是真正意義上的指針操作。
- java集合——Java中的equals和hashCode方法詳解
- Java中判斷對(duì)象是否相等的equals()方法使用教程
- Java編程中的equals方法使用全解
- java中hashCode方法與equals方法的用法總結(jié)
- 基于Java字符串 "==" 與 "equals" 的深入理解
- java中equals和等號(hào)(==)的區(qū)別淺談
- java中"==" 與equals方法的使用
- java equals函數(shù)用法詳解
- java String 類的一些理解 關(guān)于==、equals、null
- java中的equals()和toString()方法實(shí)例詳解
相關(guān)文章
SpringBoot+Redis實(shí)現(xiàn)后端接口防重復(fù)提交校驗(yàn)的示例
本文將結(jié)合實(shí)例代碼,介紹SpringBoot+Redis實(shí)現(xiàn)后端接口防重復(fù)提交校驗(yàn)的示例,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-06-06
Java基于swing實(shí)現(xiàn)的彈球游戲代碼
這篇文章主要介紹了Java基于swing實(shí)現(xiàn)的彈球游戲代碼,包含了窗體界面設(shè)計(jì)與游戲的邏輯功能處理,具有不錯(cuò)的參考借鑒價(jià)值,需要的朋友可以參考下2014-11-11
SpringBoot2.x 集成騰訊云短信的詳細(xì)流程
本文主要對(duì)SpringBoot2.x集成騰訊云短信進(jìn)行簡(jiǎn)單總結(jié),其中SpringBoot使用的2.4.5版本,本文通過(guò)業(yè)務(wù)流程圖實(shí)例代碼相結(jié)合給大家介紹的非常詳細(xì),需要的朋友參考下吧2021-06-06
SpringBoot自定義動(dòng)態(tài)數(shù)據(jù)源的流程步驟
動(dòng)態(tài)數(shù)據(jù)源,本質(zhì)上是把多個(gè)數(shù)據(jù)源存儲(chǔ)在一個(gè)?Map?中,當(dāng)需要使用某一個(gè)數(shù)據(jù)源時(shí),使用?key?獲取指定數(shù)據(jù)源進(jìn)行處理,本文將給大家介紹一下SpringBoot自定義動(dòng)態(tài)數(shù)據(jù)源的流程步驟,需要的朋友可以參考下2024-06-06
idea中javaweb的jsp頁(yè)面圖片加載不出來(lái)問(wèn)題及解決
這篇文章主要介紹了idea中javaweb的jsp頁(yè)面圖片加載不出來(lái)問(wèn)題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-07-07
Spring中使用AOP進(jìn)行事務(wù)管理實(shí)例
這篇文章主要介紹了Spring中使用AOP進(jìn)行事務(wù)管理實(shí)例,當(dāng)在Spring項(xiàng)目中涉及數(shù)據(jù)庫(kù)操作時(shí),事務(wù)管理是非常重要的,它可以確保數(shù)據(jù)庫(kù)操作的一致性和完整性,Spring提供了強(qiáng)大的事務(wù)管理功能,可以通過(guò)聲明式或編程式兩種方式進(jìn)行配置,需要的朋友可以參考下2023-09-09
mybatis?實(shí)現(xiàn)多層級(jí)collection嵌套
這篇文章主要介紹了mybatis?實(shí)現(xiàn)多層級(jí)collection嵌套,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-03-03

