java為什么不建議用equals判斷對(duì)象相等
一直以為這個(gè)方法是java8的,今天才知道是是1.7的時(shí)候,然后翻了一下源碼。
這片文章中會(huì)總結(jié)一下與a.equals(b)的區(qū)別,然后對(duì)源碼做一個(gè)小分析。
一,值是null的情況:
1.a.equals(b), a 是null, 拋出NullPointException異常。
2.a.equals(b), a不是null, b是null, 返回false
3.Objects.equals(a, b)比較時(shí), 若a 和 b 都是null, 則返回 true, 如果a 和 b 其中一個(gè)是null, 另一個(gè)不是null, 則返回false。注意:不會(huì)拋出空指針異常。
null.equals("abc") → 拋出 NullPointerException 異常
"abc".equals(null) → 返回 false
null.equals(null) → 拋出 NullPointerException 異常
Objects.equals(null, "abc") → 返回 false
Objects.equals("abc",null) → 返回 false
Objects.equals(null, null) → 返回 true
二,值是空字符串的情況:
1.a 和 b 如果都是空值字符串:””, 則 a.equals(b), 返回的值是true, 如果a和b其中有一個(gè)不是空值字符串,則返回false;
2.這種情況下 Objects.equals 與情況1 行為一致。
"abc".equals("") → 返回 false
"".equals("abc") → 返回 false
"".equals("") → 返回 true
Objects.equals("abc", "") → 返回 false
Objects.equals("","abc") → 返回 false
Objects.equals("","") → 返回 true
三,源碼分析
1.源碼
public final class Objects { private Objects() { throw new AssertionError("No java.util.Objects instances for you!"); } /** * Returns {@code true} if the arguments are equal to each other * and {@code false} otherwise. * Consequently, if both arguments are {@code null}, {@code true} * is returned and if exactly one argument is {@code null}, {@code * false} is returned. Otherwise, equality is determined by using * the {@link Object#equals equals} method of the first * argument. * * @param a an object * @param b an object to be compared with {@code a} for equality * @return {@code true} if the arguments are equal to each other * and {@code false} otherwise * @see Object#equals(Object) */ public static boolean equals(Object a, Object b) { return (a == b) || (a != null && a.equals(b)); }
2.說(shuō)明
首先,進(jìn)行了對(duì)象地址的判斷,如果是真,則不再繼續(xù)判斷。
如果不相等,后面的表達(dá)式的意思是,先判斷a不為空,然后根據(jù)上面的知識(shí)點(diǎn),就不會(huì)再出現(xiàn)空指針。
所以,如果都是null,在第一個(gè)判斷上就為true了。如果不為空,地址不同,就重要的是判斷a.equals(b)。
四,“a==b”和”a.equals(b)”有什么區(qū)別?
如果 a 和 b 都是對(duì)象,則 a==b 是比較兩個(gè)對(duì)象的引用,只有當(dāng) a 和 b 指向的是堆中的同一個(gè)對(duì)象才會(huì)返回 true。
而 a.equals(b) 是進(jìn)行邏輯比較,當(dāng)內(nèi)容相同時(shí),返回true,所以通常需要重寫(xiě)該方法來(lái)提供邏輯一致性的比較。
到此這篇關(guān)于java為什么不建議用equals判斷對(duì)象相等的文章就介紹到這了,更多相關(guān)java equals判斷對(duì)象相等內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
springboot bean掃描路徑的實(shí)現(xiàn)
這篇文章主要介紹了springboot bean掃描路徑的實(shí)現(xiàn),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2021-01-01java實(shí)現(xiàn)數(shù)字轉(zhuǎn)換人民幣中文大寫(xiě)工具
這篇文章主要為大家詳細(xì)介紹了java實(shí)現(xiàn)數(shù)字轉(zhuǎn)換人民幣中文大寫(xiě)工具,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-04-04java中 利用正則表達(dá)式提取( )內(nèi)內(nèi)容
本篇文章,小編為大家介紹關(guān)于java中 利用正則表達(dá)式提取( )內(nèi)內(nèi)容,有需要的朋友可以參考一下2013-04-04Springboot項(xiàng)目啟動(dòng)時(shí)如何用命令動(dòng)態(tài)指定環(huán)境
這篇文章主要介紹了Springboot項(xiàng)目啟動(dòng)時(shí)如何用命令動(dòng)態(tài)指定環(huán)境的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-06-06SpringBoot+Vue前后端分離實(shí)現(xiàn)審核功能的示例
在實(shí)際開(kāi)發(fā)中,審核功能是一個(gè)非常常用的功能,本文就來(lái)介紹一下使用SpringBoot+Vue前后端分離實(shí)現(xiàn)審核功能的示例,具有一定的參考價(jià)值,感興趣的可以了解一下2024-02-02關(guān)于SpringBoot Actuator漏洞補(bǔ)救方案
SpringBoot Actuator模塊提供了健康檢查,審計(jì),指標(biāo)收集,HTTP 跟蹤等,是幫助我們監(jiān)控和管理SpringBoot應(yīng)用的模塊,本文將主要介紹SpringBoot Actuator漏洞的補(bǔ)救方案,需要的朋友可以參考下2023-06-06Java實(shí)現(xiàn)求數(shù)組最長(zhǎng)子序列算法示例
這篇文章主要介紹了Java實(shí)現(xiàn)求數(shù)組最長(zhǎng)子序列算法,涉及java針對(duì)數(shù)組的遞歸遍歷、判斷相關(guān)操作技巧,需要的朋友可以參考下2018-07-07