国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - Java教程 - Java equals()方法使用詳解及總結

Java equals()方法使用詳解及總結

2020-08-21 12:11Java教程網 Java教程

這篇文章主要介紹了Java equals()方法使用詳解及總結的相關資料,需要的朋友可以參考下

equals()   

      超類Object中有這個equals()方法,該方法主要用于比較兩個對象是否相等。該方法的源碼如下:

?
1
2
3
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()方法:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
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類的:

?
1
2
3
4
public boolean equals(Object obj) {
  return (obj instanceof Float)
      && (floatToIntBits(((Float)obj).value) == floatToIntBits(value));
  }

原因嘛,里面提到了兩點:

?
1
2
3
4
5
6
7
8
9
10
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

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
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

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
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屬性。測試程序如下:

?
1
2
3
4
5
6
7
8
9
10
11
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。

感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!

原文鏈接:http://blog.csdn.net/qq_35101189/article/details/56835696

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 久久国产精品久久久久久电车 | 欧美激情精品久久久久久黑人 | 黄瓜av| 欧美午夜精品久久久久久蜜 | 999这里只有是极品 最新中文字幕在线 | 欧美午夜精品久久久久久浪潮 | 久久久久久久久久久亚洲 | 久热久爱 | 国精品一区 | 中文在线一区二区三区 | 在线中文视频 | 美女搞黄网站 | 国产天堂 | av中文字幕在线 | 成人乱码一区二区三区av | 国产成人av在线 | 欧美激情视频一区二区三区在线播放 | 成人黄网在线观看 | 日本不卡一区二区 | 黄视频在线播放 | 国产精品久久久久久久久久99 | 亚洲精品免费在线 | 国产999精品久久久久久 | 久久99精品久久久久久国产越南 | 亚洲欧美一级久久精品国产特黄 | 精品国产乱码一区二区三区 | 中文字幕视频一区 | 一区二区视频 | 日韩精品在线播放 | 成人午夜精品 | 精品一区二区三区免费毛片爱 | 免费毛片a线观看 | 久久久久久久久一区二区三区 | 国产成人久久精品一区二区三区 | 久久久一 | 国产欧美精品一区二区三区四区 | 五月天婷婷国产精品 | 欧美日韩一级视频 | 久久久99久久久国产自输拍 | 国产主播福利 | 欧美一级大片 |