欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java List中數(shù)據(jù)的去重

 更新時(shí)間:2019年01月24日 09:42:24   作者:Devin01213  
今天小編就為大家分享一篇關(guān)于Java List中數(shù)據(jù)的去重,小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧

list中數(shù)據(jù)的去重,通常使用將list轉(zhuǎn)換為set,簡(jiǎn)單直接,因?yàn)閟et集合的特點(diǎn)就是沒(méi)有重復(fù)的元素。需要考慮一下兩種情況:

1.List集合中的數(shù)據(jù)類(lèi)型是基本數(shù)據(jù)類(lèi)型

可以直接將list集合轉(zhuǎn)換成set,就會(huì)自動(dòng)去除重復(fù)的元素。

如下示例:

public class Test {
  public static void main(String[] args) {
    List list = new ArrayList();
    list.add(11);
    list.add(12);
    list.add(13);
    list.add(14);
    list.add(15);
    list.add(11);
    System.out.println(list);
    Set set = new HashSet();
    List newList = new ArrayList();
    set.addAll(list);
    newList.addAll(set);
    System.out.println(newList);
  }
}

2.List集合中存儲(chǔ)的數(shù)據(jù)類(lèi)型是對(duì)象類(lèi)型

需要在對(duì)象的實(shí)體類(lèi)中去重寫(xiě)equals()方法和hashCode()方法

public class People {
  private String name;
  private String phoneNumber;
  public String getName() {
    return name;
  }
  public void setName(String name) {
    this.name = name;
  }
  public String getPhoneNumber() {
    return phoneNumber;
  }
  public void setPhoneNumber(String phoneNumber) {
    this.phoneNumber = phoneNumber;
  }
  public People(String name, String phoneNumber) {
    super();
    this.name = name;
    this.phoneNumber = phoneNumber;
}
  @Override
  public String toString() {
    return "People{" +
        "name='" + name + ''' +
        ", phoneNumber='" + phoneNumber + ''' +
        '}';
  }
  @Override
  public boolean equals(Object o) {
    People p = (People) o;
    return name.equals(p.name) && phoneNumber.equals(p.phoneNumber);
  }
  @Override
  public int hashCode() {
    String str = name + phoneNumber;
    return str.hashCode();
  }
}
public static void main(String[] args) {
  List<People> listPeople = new ArrayList<People>();
  listPeople.add(new People("張三", "11111"));
  listPeople.add(new People("張三", "22222"));
  listPeople.add(new People("李四", "33333"));
  listPeople.add(new People("張三", "22222"));
  Set<People> setData = new HashSet<People>();
  setData.addAll(listPeople);
  System.out.println("list:" + listPeople.toString());
  System.out.println("set:" + setData.toString());
}

最后,我們拿出String中的equals()方法和hashCode()方法源碼來(lái)加深認(rèn)識(shí):

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;
  }

比較兩個(gè)對(duì)象時(shí),首先先去判斷兩個(gè)對(duì)象是否具有相同的地址,如果是同一個(gè)對(duì)象的引用,則直接放回true;如果地址不一樣,則證明不是引用同一個(gè)對(duì)象,接下來(lái)就是挨個(gè)去比較兩個(gè)字符串對(duì)象的內(nèi)容是否一致,完全相等返回true,否則false。

hashCode()

  public int hashCode() {
    int h = hash;
    if (h == 0 && count > 0) {
      int off = offset;
      char val[] = value;
      int len = count;
      for (int i = 0; i < len; i++) {
        h = 31*h + val[off++];
      }
      hash = h;
    }
    return h;
  }

hashCode()官方定義:

hashcode方法返回該對(duì)象的哈希碼值。支持該方法是為哈希表提供一些優(yōu)點(diǎn),例如,java.util.Hashtable 提供的哈希表。

hashCode 的常規(guī)協(xié)定是:

在 Java 應(yīng)用程序執(zhí)行期間,在同一對(duì)象上多次調(diào)用 hashCode 方法時(shí),必須一致地返回相同的整數(shù),前提是對(duì)象上 equals 比較中所用的信息沒(méi)有被修改。從某一應(yīng)用程序的一次執(zhí)行到同一應(yīng)用程序的另一次執(zhí)行,該整數(shù)無(wú)需保持一致。

如果根據(jù) equals(Object) 方法,兩個(gè)對(duì)象是相等的,那么在兩個(gè)對(duì)象中的每個(gè)對(duì)象上調(diào)用 hashCode 方法都必須生成相同的整數(shù)結(jié)果。

以下情況不是必需的:如果根據(jù) equals(java.lang.Object) 方法,兩個(gè)對(duì)象不相等,那么在兩個(gè)對(duì)象中的任一對(duì)象上調(diào)用 hashCode 方法必定會(huì)生成不同的整數(shù)結(jié)果。但是,程序員應(yīng)該知道,為不相等的對(duì)象生成不同整數(shù)結(jié)果可以提高哈希表的性能。

實(shí)際上,由 Object 類(lèi)定義的 hashCode 方法確實(shí)會(huì)針對(duì)不同的對(duì)象返回不同的整數(shù)。(這一般是通過(guò)將該對(duì)象的內(nèi)部地址轉(zhuǎn)換成一個(gè)整數(shù)來(lái)實(shí)現(xiàn)的,但是 JavaTM 編程語(yǔ)言不需要這種實(shí)現(xiàn)技巧。)

當(dāng)equals方法被重寫(xiě)時(shí),通常有必要重寫(xiě) hashCode 方法,以維護(hù) hashCode 方法的常規(guī)協(xié)定,該協(xié)定聲明相等對(duì)象必須具有相等的哈希碼。

總結(jié)

以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)腳本之家的支持。如果你想了解更多相關(guān)內(nèi)容請(qǐng)查看下面相關(guān)鏈接

相關(guān)文章

  • Spring?Boot快速過(guò)濾出一次請(qǐng)求的所有日志

    Spring?Boot快速過(guò)濾出一次請(qǐng)求的所有日志

    這篇文章主要介紹了Spring?Boot快速過(guò)濾出一次請(qǐng)求的所有日志,本文講述了如何使用MDC工具來(lái)快速過(guò)濾一次請(qǐng)求的所有日志,并通過(guò)裝飾器模式使得MDC工具在異步線程里也能生效,需要的朋友可以參考下
    2022-11-11
  • SpringBoot的服務(wù)注冊(cè)與發(fā)現(xiàn)示例

    SpringBoot的服務(wù)注冊(cè)與發(fā)現(xiàn)示例

    本篇文章主要介紹了SpringBoot的服務(wù)注冊(cè)與發(fā)現(xiàn)示例,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-05-05
  • SpringBoot引入Redis報(bào)Redis?command?timed?out兩種異常情況

    SpringBoot引入Redis報(bào)Redis?command?timed?out兩種異常情況

    這篇文章主要給大家介紹了關(guān)于SpringBoot引入Redis報(bào)Redis?command?timed?out兩種異常情況的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-08-08
  • Java之Mybatis多層嵌套查詢(xún)方式

    Java之Mybatis多層嵌套查詢(xún)方式

    這篇文章主要介紹了Java之Mybatis多層嵌套查詢(xún)方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-03-03
  • Java RPC框架如何實(shí)現(xiàn)客戶(hù)端限流配置

    Java RPC框架如何實(shí)現(xiàn)客戶(hù)端限流配置

    這篇文章主要介紹了Java RPC框架如何實(shí)現(xiàn)客戶(hù)端限流配置,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-02-02
  • 詳解Java如何使用責(zé)任鏈默認(rèn)優(yōu)雅地進(jìn)行參數(shù)校驗(yàn)

    詳解Java如何使用責(zé)任鏈默認(rèn)優(yōu)雅地進(jìn)行參數(shù)校驗(yàn)

    項(xiàng)目中參數(shù)校驗(yàn)十分重要,它可以保護(hù)我們應(yīng)用程序的安全性和合法性。這篇文章主要介紹了如何使用責(zé)任鏈默認(rèn)優(yōu)雅地進(jìn)行參數(shù)校驗(yàn),需要的可以參考一下
    2023-03-03
  • Java Web端程序?qū)崿F(xiàn)文件下載的方法分享

    Java Web端程序?qū)崿F(xiàn)文件下載的方法分享

    這篇文章主要介紹了Java Web端程序?qū)崿F(xiàn)文件下載的方法分享,包括一個(gè)包含防盜鏈功能的專(zhuān)門(mén)針對(duì)圖片下載的程序代碼示例,需要的朋友可以參考下
    2016-05-05
  • JUC之CountdownLatch使用詳解

    JUC之CountdownLatch使用詳解

    這篇文章主要介紹了JUC之CountdownLatch使用詳解,CountdownLatch 用來(lái)進(jìn)行線程同步協(xié)作,等待所有線程完成倒計(jì)時(shí),
    其中構(gòu)造參數(shù)用來(lái)初始化等待計(jì)數(shù)值,await() 用來(lái)等待計(jì)數(shù)歸零,countDown() 用來(lái)讓計(jì)數(shù)減一,需要的朋友可以參考下
    2023-12-12
  • public?static?void?main(String[]?args)使用解讀

    public?static?void?main(String[]?args)使用解讀

    這篇文章主要介紹了public?static?void?main(String[]?args)的使用,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-01-01
  • springmvc 中dao層和service層的區(qū)別說(shuō)明

    springmvc 中dao層和service層的區(qū)別說(shuō)明

    這篇文章主要介紹了springmvc 中dao層和service層的區(qū)別說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-08-08

最新評(píng)論