亚洲国产日韩欧美一区二区三区,精品亚洲国产成人av在线,国产99视频精品免视看7,99国产精品久久久久久久成人热,欧美日韩亚洲国产综合乱

目錄
java HashMap插入重複Key值
put方法
實作引用物件作為keys的唯一性
HashMap解決key值相同問題
首頁 Java java教程 基於Java HashMap,如何解決插入重複的Key值問題

基於Java HashMap,如何解決插入重複的Key值問題

May 09, 2023 am 10:52 AM
java hashmap

java HashMap插入重複Key值

要在HashMap中插入重複的值,首先要先弄清楚HashMap裡面是怎麼存放元素的。

put方法

Map裡面存放的每一個元素都是key-value這樣的鍵值對,而且都是透過put方法進行新增的,而且相同的key在Map中只會有一個與之關聯(lián)的value存在。 put方法在Map中的定義如下。

V put(K key, V value);

put()方法實作:

首先hash(key)得到key的hashcode(),hashmap根據(jù)所得的hashcode找到要插入的位置所在的鏈,在這個鏈裡面放的都是hashcode相同的Entry鍵值對,在找到這個鏈之後,會透過equals()方法判斷是否已經(jīng)存在要插入的鍵值對,而這個equals比較的其實就是key。

它用來存放key-value這樣的一個鍵值對,傳回值是key在Map中存放的舊value,如果之前不存在則傳回null。 HashMap的put方法就是這樣實現(xiàn)的。

// 在此映射中關聯(lián)指定值與指定鍵。如果該映射以前包含了一個該鍵的映射關系,則舊值被替換
public V put(K key, V value) {
    // 當key為null,調用putForNullKey方法,保存null與table第一個位置中,這是HashMap允許為null的原因 
    if (key == null)
        return putForNullKey(value);
    // 使用hash函數(shù)預處理hashCode,計算key的hash值  
    int hash = hash(key.hashCode());//-------(1)
    // 計算key hash 值在 table 數(shù)組中的位置 
    int i = indexFor(hash, table.length);//------(2)
    // 從i出開始迭代 e,找到 key 保存的位置
    for (Entry<K, V> e = table[i]; e != null; e = e.next) {
        Object k;
        // 判斷該條鏈上是否有hash值相同的(key相同) 
        // 若存在相同,則直接覆蓋value,返回舊value 
        if (e.hash == hash && ((k = e.key) == key || key.equals(k))) {
            // 舊值 = 新值  
            V oldValue = e.value;
            // 將要存儲的value存進去
            e.value = value;
            e.recordAccess(this);
            // 返回舊的value
            return oldValue;
        }
    }
    // 修改次數(shù)增加1 
    modCount++;
    // 將key、value添加至i位置處 
    addEntry(hash, key, value, i);
    return null;
}

從上我們可以看到在新增對應的key-value這樣的組合時,如果原本已經(jīng)存在對應的key,則直接改變對應的value,並傳回舊的value,而在判斷key是否存在的時候是先比較key的hashCode,再比較相等或equals的。

直接從上面程式碼來看是比較的對應Map.Entry的hashCode和key的hashCode,而實際上Map.Entry的hashCode其實就是其存放key的hashCode。

而如果對應的key原本不存在的話將呼叫addEntry將對應的key-value加入Map。

addEntry傳遞的參數(shù)hash就是對應key的hashCode。

實作引用物件作為keys的唯一性

透過對put()方法的研究,我們可以發(fā)現(xiàn),判斷key是否存在的時候是先比較key的hashCode,再比較相等或equals的,所以重寫hashCode()和equals()方法即可實現(xiàn)覆蓋keys的參考(指向具有相同實例變數(shù)的物件)。

class MyType {
    private String arga;
    private String argb;

    public MyType(String arga, String argb) {
        this.arga = arga;
        this.argb = argb;
    }

    @Override
    public int hashCode(){                 
         return this.arga.hashCode() * this.argb.hashCode() ; 
    } 
    
    @Override
    public boolean equals(Object obj) {   
        if (this == obj) {               
            return true;                  
        }         
        if (!(obj instanceof MyType)) {  
            return false;               
        }    
        MyType p = (MyType) obj;  
        if (this.arga.equals(p.arga) && this.argb.equals(p.argb)) {              
            return true ;                  
        } else {           
            return false ;                
        }       
    }
}

重寫這兩個方法之後就可以覆蓋重複的引用對象,如果需要對value進行疊加,調用put()方法之前用containsKey()方法判斷是否有重複的鍵值,如果有,則用get()方法取得原有的value,再加上新加入的value即可。

HashMap解決key值相同問題

某些場景需要一個key值下面對應多個值,但是map的一個key值只對應一個value值,由於hashmap相同的key值,第二個put進去會覆寫第一個的值,所以為了解決這個問題:所以用list存

如下:

List<Map<String, List<RecommendationListBO>>> hashList = new ArrayList<>();
Iterator<Map.Entry<String, List<RecommendationListBO>>> iterator = recommendationHashMap.entrySet().iterator();
Map.Entry<String, List<RecommendationListBO>> entry;
while (iterator.hasNext()) {
    entry = iterator.next();
    // 往newMap中放入新的Entry
    HashMap<String, List<RecommendationListBO>> newMap = new LinkedHashMap<>();
    newMap.put(entry.getKey().split(",")[0], entry.getValue());
    hashList.add(newMap);
}

每次new一個新的map,add到map的list裡面。思路大概是這樣的。

以上是基於Java HashMap,如何解決插入重複的Key值問題的詳細內容。更多資訊請關注PHP中文網(wǎng)其他相關文章!

本網(wǎng)站聲明
本文內容由網(wǎng)友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發(fā)現(xiàn)涉嫌抄襲或侵權的內容,請聯(lián)絡admin@php.cn

熱AI工具

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創(chuàng)建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發(fā)環(huán)境

Dreamweaver CS6

Dreamweaver CS6

視覺化網(wǎng)頁開發(fā)工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

熱門話題

Laravel 教程
1597
29
PHP教程
1488
72
VSCODE設置。 JSON位置 VSCODE設置。 JSON位置 Aug 01, 2025 am 06:12 AM

settings.json文件位於用戶級或工作區(qū)級路徑,用於自定義VSCode設置。 1.用戶級路徑:Windows為C:\Users\\AppData\Roaming\Code\User\settings.json,macOS為/Users//Library/ApplicationSupport/Code/User/settings.json,Linux為/home//.config/Code/User/settings.json;2.工作區(qū)級路徑:項目根目錄下的.vscode/settings

如何使用JDBC處理Java的交易? 如何使用JDBC處理Java的交易? Aug 02, 2025 pm 12:29 PM

要正確處理JDBC事務,必須先關閉自動提交模式,再執(zhí)行多個操作,最後根據(jù)結果提交或回滾;1.調用conn.setAutoCommit(false)以開始事務;2.執(zhí)行多個SQL操作,如INSERT和UPDATE;3.若所有操作成功則調用conn.commit(),若發(fā)生異常則調用conn.rollback()確保數(shù)據(jù)一致性;同時應使用try-with-resources管理資源,妥善處理異常並關閉連接,避免連接洩漏;此外建議使用連接池、設置保存點實現(xiàn)部分回滾,並保持事務盡可能短以提升性能。

在Java的掌握依賴注入春季和Guice 在Java的掌握依賴注入春季和Guice Aug 01, 2025 am 05:53 AM

依賴性(di)IsadesignpatternwhereObjectsReceivedenciesenciesExtern上,推廣looseSecouplingAndEaseerTestingThroughConstructor,setter,orfieldInjection.2.springfraMefringframeWorkSannotationsLikeLikeLike@component@component,@component,@service,@autowiredwithjava-service和@autowiredwithjava-ligatiredwithjava-lase-lightike

Python Itertools組合示例 Python Itertools組合示例 Jul 31, 2025 am 09:53 AM

itertools.combinations用於生成從可迭代對像中選取指定數(shù)量元素的所有不重複組合(順序無關),其用法包括:1.從列表中選2個元素組合,如('A','B')、('A','C')等,避免重複順序;2.對字符串取3個字符組合,如"abc"、"abd",適用於子序列生成;3.求兩數(shù)之和等於目標值的組合,如1 5=6,簡化雙重循環(huán)邏輯;組合與排列的區(qū)別在於順序是否重要,combinations視AB與BA為相同,而permutations視為不同;

故障排除常見的java`ofmemoryError`場景'' 故障排除常見的java`ofmemoryError`場景'' Jul 31, 2025 am 09:07 AM

java.lang.OutOfMemoryError:Javaheapspace表示堆內存不足,需檢查大對象處理、內存洩漏及堆設置,通過堆轉儲分析工具定位並優(yōu)化代碼;2.Metaspace錯誤因類元數(shù)據(jù)過多,常見於動態(tài)類生成或熱部署,應限制MaxMetaspaceSize並優(yōu)化類加載;3.Unabletocreatenewnativethread因係統(tǒng)線程資源耗盡,需檢查線程數(shù)限制、使用線程池、調整棧大??;4.GCoverheadlimitexceeded指GC頻繁但回收少,應分析GC日誌,優(yōu)化

Python Pytest夾具示例 Python Pytest夾具示例 Jul 31, 2025 am 09:35 AM

fixture是用於為測試提供預設環(huán)境或數(shù)據(jù)的函數(shù),1.使用@pytest.fixture裝飾器定義fixture;2.在測試函數(shù)中以參數(shù)形式註入fixture;3.yield之前執(zhí)行setup,之後執(zhí)行teardown;4.通過scope參數(shù)控製作用域,如function、module等;5.將共用fixture放在conftest.py中實現(xiàn)跨文件共享,從而提升測試的可維護性和復用性。

了解Java虛擬機(JVM)內部 了解Java虛擬機(JVM)內部 Aug 01, 2025 am 06:31 AM

TheJVMenablesJava’s"writeonce,runanywhere"capabilitybyexecutingbytecodethroughfourmaincomponents:1.TheClassLoaderSubsystemloads,links,andinitializes.classfilesusingbootstrap,extension,andapplicationclassloaders,ensuringsecureandlazyclassloa

如何使用Java的日曆? 如何使用Java的日曆? Aug 02, 2025 am 02:38 AM

使用java.time包中的類替代舊的Date和Calendar類;2.通過LocalDate、LocalDateTime和LocalTime獲取當前日期時間;3.使用of()方法創(chuàng)建特定日期時間;4.利用plus/minus方法不可變地增減時間;5.使用ZonedDateTime和ZoneId處理時區(qū);6.通過DateTimeFormatter格式化和解析日期字符串;7.必要時通過Instant與舊日期類型兼容;現(xiàn)代Java中日期處理應優(yōu)先使用java.timeAPI,它提供了清晰、不可變且線

See all articles