您好,登錄后才能下訂單哦!
本篇文章給大家分享的是有關equals()方法如何在Java項目中使用,小編覺得挺實用的,因此分享給大家學習,希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。
equals()
超類Object中有這個equals()方法,該方法主要用于比較兩個對象是否相等。該方法的源碼如下:
public boolean equals(Object obj) { return (this == obj); }
我們知道所有的對象都擁有標識(內存地址)和狀態(數據),同時“==”比較兩個對象的的內存地址,所以說使用Object的equals()方法是比較兩個對象的內存地址是否相等,即若object1.equals(object2)為true,則表示equals1和equals2實際上是引用同一個對象。雖然有時候Object的equals()方法可以滿足我們一些基本的要求,但是我們必須要清楚我們很大部分時間都是進行兩個對象的比較,這個時候Object的equals()方法就不可以了,實際上JDK中,String、Math等封裝類都對equals()方法進行了重寫。下面是String的equals()方法:
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; }
對于這個代碼段:if (v1[i++] != v2[j++])return false;我們可以非常清晰的看到String的equals()方法是進行內容比較,而不是引用比較。至于其他的封裝類都差不多。
在Java規范中,它對equals()方法的使用必須要遵循如下幾個規則:
equals 方法在非空對象引用上實現相等關系:
1、自反性:對于任何非空引用值 x,x.equals(x) 都應返回 true。
2、對稱性:對于任何非空引用值 x 和 y,當且僅當 y.equals(x) 返回 true 時,x.equals(y) 才應返回 true。
3、傳遞性:對于任何非空引用值 x、y 和 z,如果 x.equals(y) 返回 true,并且 y.equals(z) 返回 true,那么 x.equals(z) 應返回 true。
4、一致性:對于任何非空引用值 x 和 y,多次調用 x.equals(y) 始終返回 true 或始終返回 false,前提是對象上 equals 比較中所用的信息沒有被修改。
5、 對于任何非空引用值 x,x.equals(null) 都應返回 false。
對于上面幾個規則,我們在使用的過程中最好遵守,否則會出現意想不到的錯誤。
在java中進行比較,我們需要根據比較的類型來選擇合適的比較方式:
1) 對象域,使用equals方法 。
2) 類型安全的枚舉,使用equals或== 。
3) 可能為null的對象域 : 使用 == 和 equals 。
4) 數組域 : 使用 Arrays.equals 。
5) 除float和double外的原始數據類型 : 使用 == 。
6) float類型: 使用Float.foatToIntBits轉換成int類型,然后使用==。
7) double類型: 使用Double.doubleToLongBit轉換成long類型,然后使用==。
至于6)、7)為什么需要進行轉換,我們可以參考他們相應封裝類的equals()方法,下面的是Float類的:
public boolean equals(Object obj) { return (obj instanceof Float) && (floatToIntBits(((Float)obj).value) == floatToIntBits(value)); }
原因嘛,里面提到了兩點:
However, there are two exceptions: If f1 and f2 both represent Float.NaN, then the equals method returns true, even though Float.NaN==Float.NaN has the value false. If <code>f1 represents +0.0f while f2 represents -0.0f, or vice versa, the equal test has the value false, even though 0.0f==-0.0f has the value true.
在equals()中使用getClass進行類型判斷
我們在覆寫equals()方法時,一般都是推薦使用getClass來進行類型判斷,不是使用instanceof。我們都清楚instanceof的作用是判斷其左邊對象是否為其右邊類的實例,返回boolean類型的數據。可以用來判斷繼承中的子類的實例是否為父類的實現。注意后面這句話:可以用來判斷繼承中的子類的實例是否為父類的實現,正是這句話在作怪。我們先看如下實例(摘自《高質量代碼 改善java程序的151個建議》)。
父類:Person
public class Person { protected String name; public String getName() { return name; } public void setName(String name) { this.name = name; } public Person(String name){ this.name = name; } public boolean equals(Object object){ if(object instanceof Person){ Person p = (Person) object; if(p.getName() == null || name == null){ return false; } else{ return name.equalsIgnoreCase(p.getName()); } } return false; } }
子類:Employee
public class Employee extends Person{ private int id; public int getId() { return id; } public void setId(int id) { this.id = id; } public Employee(String name,int id){ super(name); this.id = id; } /** * 重寫equals()方法 */ public boolean equals(Object object){ if(object instanceof Employee){ Employee e = (Employee) object; return super.equals(object) && e.getId() == id; } return false; } }
上面父類Person和子類Employee都重寫了equals(),不過Employee比父類多了一個id屬性。測試程序如下:
public class Test { public static void main(String[] args) { Employee e1 = new Employee("chenssy", 23); Employee e2 = new Employee("chenssy", 24); Person p1 = new Person("chenssy"); System.out.println(p1.equals(e1)); System.out.println(p1.equals(e2)); System.out.println(e1.equals(e2)); } }
上面定義了兩個員工和一個普通人,雖然他們同名,但是他們肯定不是同一人,所以按理來說輸出結果應該全部都是false,但是事與愿違,結果是:true、true、false。
對于那e1!=e2我們非常容易理解,因為他們不僅需要比較name,還需要比較id。但是p1即等于e1也等于e2,這是非常奇怪的,因為e1、e2明明是兩個不同的類,但為什么會出現這個情況?首先p1.equals(e1),是調用p1的equals方法,該方法使用instanceof關鍵字來檢查e1是否為Person類,這里我們再看看instanceof:判斷其左邊對象是否為其右邊類的實例,也可以用來判斷繼承中的子類的實例是否為父類的實現。他們兩者存在繼承關系,肯定會返回true了,而兩者name又相同,所以結果肯定是true。
所以出現上面的情況就是使用了關鍵字instanceof,這是非常容易“專空子”的。故在覆寫equals時推薦使用getClass進行類型判斷。而不是使用instanceof。
以上就是equals()方法如何在Java項目中使用,小編相信有部分知識點可能是我們日常工作會見到或用到的。希望你能通過這篇文章學到更多知識。更多詳情敬請關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。