激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

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

服務(wù)器之家 - 編程語言 - Java教程 - Java Set集合去重的原理及實(shí)現(xiàn)

Java Set集合去重的原理及實(shí)現(xiàn)

2020-09-09 00:20崔笑顏 Java教程

這篇文章主要介紹了Java Set集合去重的原理及實(shí)現(xiàn),幫助大家更好的理解和學(xué)習(xí)Java,感興趣的朋友可以了解下

在開發(fā)中經(jīng)常使用到Set集合去重,那么去重的原理是怎樣實(shí)現(xiàn)的呢?在此文章記錄一下去重原理!!!

下面是set集合類圖

Java Set集合去重的原理及實(shí)現(xiàn)

下面我們來跟蹤一下執(zhí)行過程;

首先我們實(shí)例化一個(gè)Set對象;

?
1
2
Set<8大基本類型> set = new HashSet<8大基本類型>();
set.add(8大基本類型);

add操作會(huì)調(diào)用HashMap中的add方法;

?
1
2
3
public boolean add(E e) {
    return map.put(e, PRESENT)==null;
    }

HashMap中的add方法依賴了HashMap的put方法;

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
public V put(K key, V value) {
    if (key == null)
      return putForNullKey(value);
    int hash = hash(key.hashCode());
    int i = indexFor(hash, table.length);
    for (Entry<K,V> e = table[i]; e != null; e = e.next) {//每添加一個(gè),則循環(huán)判斷是否與map中的元素相等
      Object k;
      // 先判斷hashcode是否一致,然后再判斷值是否相等
      if (e.hash == hash && ((k = e.key) == key || key.equals(k))) {
        V oldValue = e.value;
        e.value = value;
        e.recordAccess(this);
        return oldValue;
      }
    }
 
    modCount++;
    addEntry(hash, key, value, i);
    return null;
  }

但是上述方法只對基本數(shù)據(jù)類型有效,下面是應(yīng)用到復(fù)雜對象的講解。
下面就是重寫對象User的實(shí)現(xiàn),重寫equals和hashCode方法;

測試類

?
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
29
30
31
32
33
34
35
36
37
38
39
40
41
42
public class User {
  //id
  protected Integer id;
  //username
  protected String username;
 
  //構(gòu)造方法
  public User(int id,String username){
    this.id = id;
    this.username = username;
  }
 
  /**
   * 如果對象是USER,先比較hashcode,一致的場合在比價(jià)每個(gè)屬性的值
   */
  @Override
  public boolean equals(Object obj) {
    if(obj == null)
      return false;
    if(this == obj)
      return true;
    if(obj instanceof User){
      User user = (User) obj;
      //if(user.id == this.id) return true; //只比較id
      //比較id和username 一致時(shí)才返回true,之后再去比較hashCode
      if(user.id == this.id && user.username.equals(this.username)){
        return true;
      }
    }
    return false;
  }
 
  /**
   *
   * 重寫hashCode方法,返回的hashCode不一樣 才認(rèn)為是不一樣的對象;
   */
  @Override
  public int hashCode() {
    //return id.hashCode(); 只比較id,id不一樣就添加進(jìn)集合;
    return id.hashCode() * username.hashCode();
  }
}

實(shí)現(xiàn)類

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
import java.util.HashSet;
import java.util.Set;
 
public class test {
  public static void main(String[] args){
    User user1 = new User(1,"xiaoqiang");
    User user2 = new User(2,"xiaoqiang");
    User user3 = new User(1,"xiaoqiang");
    User user4 = new User(1,"xiaoqiang");
 
    Set<User> set = new HashSet<User>();
    set.add(user1);
    set.add(user2);
    set.add(user3);
    set.add(user4);
    for(User u : set){
      System.out.println("id:" + u.id +" username:"+ u.username);
    }
  }
}

輸出結(jié)果

id:2 username:xiaoqiang
id:1 username:xiaoqiang

以上就是Java Set集合去重的原理及實(shí)現(xiàn)的詳細(xì)內(nèi)容,更多關(guān)于Java Set集合去重的資料請關(guān)注服務(wù)器之家其它相關(guān)文章!

原文鏈接:https://cloud.tencent.com/developer/article/1649007

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 99精品国产成人一区二区 | 黄色7777 | 国产精品久久久久永久免费观看 | 成人在线视频精品 | 福利在线国产 | 国产九九九九 | 国产在线精品区 | 国产一区二区三区四区波多野结衣 | 国产男女 爽爽爽爽视频 | 久久久久久久久久久av | chinese xvideos gay | 72pao成人国产永久免费视频 | 一级电影免费在线观看 | 午夜视频在线在免费 | 黄色男女视频 | 国产成人在线一区二区 | 久久久久久久久久性 | 蜜桃视频观看麻豆 | 亚洲精品xxx | 亚洲最新色 | 免费高清一级欧美片在线观看 | 97中文| 久久久久久中文字幕 | 成人精品视频在线 | 香蕉久久久久久 | 在线观看网址av | 国产在线一级片 | h视频免费在线观看 | 亚洲成人播放 | 农村寡妇偷毛片一级 | 日韩视频在线不卡 | 亚洲一区二区 | 免费国产成人高清在线看软件 | 中文字幕在线观看免费视频 | 宅男噜噜噜66一区二区 | 婷婷一区二区三区四区 | ⅴideo裸体秀hd | av在线收看| 精品一区二区三区电影 | 亚洲国产精品二区 | 国产 日韩 一区 |