一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

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

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

服務(wù)器之家 - 編程語(yǔ)言 - 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,感興趣的朋友可以了解下

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

下面是set集合類(lèi)圖

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

下面我們來(lái)跟蹤一下執(zhí)行過(guò)程;

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

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

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

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

測(cè)試類(lèi)

?
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;
  }
 
  /**
   * 如果對(duì)象是USER,先比較hashcode,一致的場(chǎng)合在比價(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;
  }
 
  /**
   *
   * 重寫(xiě)hashCode方法,返回的hashCode不一樣 才認(rèn)為是不一樣的對(duì)象;
   */
  @Override
  public int hashCode() {
    //return id.hashCode(); 只比較id,id不一樣就添加進(jìn)集合;
    return id.hashCode() * username.hashCode();
  }
}

實(shí)現(xiàn)類(lèi)

?
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集合去重的資料請(qǐng)關(guān)注服務(wù)器之家其它相關(guān)文章!

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

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 亚洲精品一二三四 | 动漫人物差差差动漫人物免费观看 | 国产一区二区三区四区波多野结衣 | 熟睡迷j系列小说 | 牛牛影院成人免费网页 | 青青草高清视频 | 果冻传媒天美传媒在线小视频播放 | 亚洲香蕉网久久综合影院3p | 国产成人v爽在线免播放观看 | 和直男装修工在工地啪 | 国产视频一二三区 | 国产伦精品一区二区 | 国产在线视频一区二区三区 | 国内永久第一免费福利视频 | 91成| 四虎最新永久免费视频 | 日本又大又硬又粗的视频 | 亚洲精品第一国产综合高清 | 精品国产自在在线在线观看 | 青青青青青操 | 王雨纯 羞羞 | 99在线观看视频免费精品9 | 亚洲另类激情 | 久久国产热视频99rev6 | 蜜桃久久久亚洲精品成人 | 大jjjj免费看视频 | 超兴奋朋友的中文字幕下 | piss美女厕所小便 | 精品久久久久久久久久久久久久久 | 日本人成动漫网站在线观看 | 四虎成人影院网址 | 精品国产日韩一区三区 | 亚洲人的天堂男人爽爽爽 | 丰满肥臀风间由美357在线 | 国产成人久久精品推最新 | 日本人护士免费xxxx视频 | 91.久久| 午夜视频在线网站 | 国产大片51精品免费观看 | 日本欧美强乱视频在线 | 精品人伦一区二区三区潘金莲 |