== 和 equals 的區(qū)別是什么?
== 和 equals 的區(qū)別是什么?
== 解讀
對于基本類型和引用類型 == 的作用效果是不同的,如下所示:
·?基本類型:比較的是值是否相同;
·?引用類型:比較的是引用是否相同;
代碼示例:
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()方法則重寫開辟了內(nèi)存空間,所以 == 結(jié)果為 false,而 equals 比較的一直是值,所以結(jié)果都為 true。
equals 解讀
equals 本質(zhì)上就是 ==,只不過 String 和 Integer 等重寫了 equals 方法,把它變成了值比較。看下面的代碼就明白了。
首先來看默認情況下 equals 比較一個有相同值的對象,代碼如下:
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
輸出結(jié)果出乎我們的意料,竟然是 false?這是怎么回事,看了 equals 源碼就知道了,源碼如下:
public?boolean?equals(Object obj) {
????????return?(this?== obj);
}
原來 equals 本質(zhì)上就是 ==。
那問題來了,兩個相同值的 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 方法,把引用比較改成了值比較。
總結(jié)?:== 對于基本類型來說是值比較,對于引用類型來說是比較的是引用;而 equals 默認情況下是引用比較,只是很多類重新了 equals 方法,比如 String、Integer 等把它變成了值比較,所以一般情況下 equals 比較的是值是否相等。