日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) >

HashMap底层原理分析(put、get方法)

發(fā)布時(shí)間:2025/7/25 70 豆豆
生活随笔 收集整理的這篇文章主要介紹了 HashMap底层原理分析(put、get方法) 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

?

1、HashMap底層原理分析(put、get方法)

HashMap底層是通過(guò)數(shù)組加鏈表的結(jié)構(gòu)來(lái)實(shí)現(xiàn)的。HashMap通過(guò)計(jì)算key的hashCode來(lái)計(jì)算hash值,只要hashCode一樣,那hash值就是相同的。當(dāng)hash值相同時(shí),就會(huì)出現(xiàn)hash沖突,HashMap通過(guò)鏈表來(lái)解決沖突。

原理圖:

?

實(shí)例:

import java.util.HashMap; import java.util.Map; ? public class HashMapTest {public static void main(String[] args) {Map<String, String> map = new HashMap<>();map.put("fruit", "apple");System.out.println(map.get("fruit"));

?

1、put方法分析

//添加鍵值對(duì)方法 public V put(K key, V value) {//如果key為null,則hash值為0,將這個(gè)entry放在索引為0的地方,即table[0]if (key == null)return putForNullKey(value);//key不為nullint hash = hash(key.hashCode());//計(jì)算key的hashCode的hash值int i = indexFor(hash, table.length);//返回hash值所在的索引位置//遍歷table[i]處的Entry,若存在key相同并且hash值相同,則用新元素替換舊元素for (Entry<K,V> e = table[i]; e != null; e = e.next) {Object k;if (e.hash == hash && ((k = e.key) == key || key.equals(k))) {V oldValue = e.value;e.value = value;e.recordAccess(this);return oldValue;}}//修改標(biāo)記+1,然后進(jìn)行元素添加操作modCount++;addEntry(hash, key, value, i);//將包含特定key、value和hash值的entry添加到特定的桶中return null;}//添加key為null的元素private V putForNullKey(V value) {for (Entry<K,V> e = table[0]; e != null; e = e.next) {if (e.key == null) {V oldValue = e.value;e.value = value;e.recordAccess(this);return oldValue;}}modCount++;addEntry(0, null, value, 0);return null;}/*** Adds a new entry with the specified key, value and hash code to* the specified bucket. It is the responsibility of this* method to resize the table if appropriate.** Subclass overrides this to alter the behavior of put method.*/void addEntry(int hash, K key, V value, int bucketIndex) {Entry<K,V> e = table[bucketIndex];table[bucketIndex] = new Entry<>(hash, key, value, e);if (size++ >= threshold)resize(2 * table.length);}

?

2、get方法分析

/** * 返回映射的key對(duì)應(yīng)的value值,若map不包含該key,返回null */ public V get(Object key) {if (key == null)//獲取key為null的value值return getForNullKey();int hash = hash(key.hashCode());//計(jì)算key的hashCode的hash值//遍歷數(shù)組中對(duì)應(yīng)hash值的Entry鏈表,若Entry元素的hash值與hashCode的hash值相等并且key與查找的key相等,則返回此Entry元素的value值for (Entry<K,V> e = table[indexFor(hash, table.length)];e != null;e = e.next) {Object k;if (e.hash == hash && ((k = e.key) == key || key.equals(k)))return e.value;}return null;}

?

轉(zhuǎn)載于:https://www.cnblogs.com/stm32stm32/p/9035519.html

總結(jié)

以上是生活随笔為你收集整理的HashMap底层原理分析(put、get方法)的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。