在 Java 中,HashMap 的 `Entry` 表示 HashMap 中的一個(gè)鍵值對(duì)(key-value pair)。每個(gè) Entry 對(duì)象包含一個(gè)鍵(key)和對(duì)應(yīng)的值(value)。
在 HashMap 內(nèi)部,鍵值對(duì)以 Entry 對(duì)象的形式存儲(chǔ)在桶(bucket)中。HashMap 使用哈希函數(shù)計(jì)算鍵的哈希碼,并根據(jù)哈希碼將鍵值對(duì)分配到不同的桶中。每個(gè)桶可以包含一個(gè)或多個(gè) Entry 對(duì)象,當(dāng)發(fā)生哈希沖突時(shí),多個(gè) Entry 對(duì)象會(huì)以鏈表或紅黑樹的形式存儲(chǔ)在同一個(gè)桶中。
HashMap 的 `Entry` 類是一個(gè)內(nèi)部類,定義在 HashMap 類中。它包含以下幾個(gè)重要的屬性和方法:
- `key`:表示鍵的值。
- `value`:表示鍵對(duì)應(yīng)的值。
- `next`:表示鏈表或樹中的下一個(gè) Entry 對(duì)象。
- `hash`:表示鍵的哈希碼。
通過使用 `Entry` 對(duì)象,HashMap 可以存儲(chǔ)和檢索鍵值對(duì),并支持高效的查找操作??梢酝ㄟ^迭代 HashMap 的 `entrySet()` 方法來遍歷所有的鍵值對(duì),或者使用 `get(key)` 方法通過鍵來獲取對(duì)應(yīng)的值。
需要注意的是,從 Java 8 開始,HashMap 的實(shí)現(xiàn)在桶中鏈表長(zhǎng)度達(dá)到一定閾值時(shí),會(huì)將鏈表轉(zhuǎn)化為紅黑樹,以提高查找效率。這種情況下,桶中的 Entry 對(duì)象可能是鏈表節(jié)點(diǎn)或紅黑樹節(jié)點(diǎn),而非僅限于鏈表。
總之,HashMap 的 `Entry` 表示鍵值對(duì)的數(shù)據(jù)結(jié)構(gòu),它是 HashMap 內(nèi)部用來存儲(chǔ)和管理鍵值對(duì)的重要組成部分。