在 Java 中 == 和 equals 的區別,是面試必問的問題,然而只有不多的面試者才能徹底回答正確。java
常見的錯誤回答就是:== 基礎類型對比的是值是否相同,引用類型對比的是引用是否相同;而 equals 則是比較的值是否相同。程序員
至於爲何說它是錯的,看完本文對 == 和 equals 的解讀,你就知道了。面試
對於基本類型和引用類型 == 的做用效果是不一樣的,以下所示:markdown
代碼示例:post
String x = "string"; String y = "string"; String z = new String("string"); System.out.println(x==y); // true System.out.println(x==z); // false System.out.println(x.equals(y)); // true System.out.println(x.equals(z)); // true 複製代碼
代碼解讀:由於 x 和 y 指向的是同一個引用,因此 == 也是 true,而 new String()方法則重寫開闢了內存空間,因此 == 結果爲 false,而 equals 比較的一直是值,因此結果都爲 true。this
equals 本質上就是 ==,只不過 String 和 Integer 等重寫了 equals 方法,把它變成了值比較。看下面的代碼就明白了。spa
首先來看默認狀況下 equals 比較一個有相同值的對象,代碼以下:3d
class Cat { public Cat(String name) { this.name = name; } private String name; public String getName() { return name; } public void setName(String name) { this.name = name; } } Cat c1 = new Cat("王磊"); Cat c2 = new Cat("王磊"); System.out.println(c1.equals(c2)); // false 複製代碼
輸出結果出乎咱們的意料,居然是 false?這是怎麼回事,看了 equals 源碼就知道了,源碼以下:code
public boolean equals(Object obj) { return (this == obj); } 複製代碼
原來 equals 本質上就是 ==。orm
那問題來了,兩個相同值的 String 對象,爲何返回的是 true?代碼以下:
String s1 = new String("老王"); String s2 = new String("老王"); System.out.println(s1.equals(s2)); // true 複製代碼
一樣的,當咱們進入 String 的 equals 方法,找到了答案,代碼以下:
public boolean equals(Object anObject) { if (this == anObject) { return true; } if (anObject instanceof String) { String anotherString = (String)anObject; int n = value.length; if (n == anotherString.value.length) { char v1[] = value; char v2[] = anotherString.value; int i = 0; while (n-- != 0) { if (v1[i] != v2[i]) return false; i++; } return true; } } return false; } 複製代碼
原來是 String 重寫了 Object 的 equals 方法,把引用比較改爲了值比較。
整體來講,== 對於基本類型來講是值比較,對於引用類型來講是比較的是引用;而 equals 默認狀況下是引用比較,只是不少類重寫了 equals 方法,好比 String、Integer 等把它變成了值比較,因此通常狀況下 equals 比較的是值是否相等。
掃描下方二維碼,關注更多動態:
系列文章推薦: