HashMap詳解七
使用 Iterator 遍歷
通過 HashMap.entrySet().iterator() 方法獲取迭代器, 使用 next 方法對 HashMap 進行遍歷.
HashMap<String, String> map = new HashMap<>();
Iterator it = map.entrySet().iterator();
while(it.hasNext()) {
Map.Entry<String, String> entry = it.next();
}
下面詳細講解各個方法的作用, 其實迭代器之所以能遍歷元素節點, 主要是應用了內部類. 通過內部類可以訪問外部類的變數和方法, 從而完成遍歷節點.
entrySet()
/**
* 直接返回 EntrySet 的例項
* 注意這裡 entrySet 不是靜態方法, 而 EntrySet 是非靜態的內部類, 所以可以直接 new 例項
*/
public Set<Map.Entry<K,V>> entrySet() {
Set<Map.Entry<K,V>> es;
return (es = entrySet) == null ? (entrySet = new EntrySet()) : es;
}
EntrySet
/**
* EntrySet 繼承於 AbstractSet
*/
final class EntrySet extends AbstractSet<Map.Entry<K,V>> {
...
/**
* 返回 EntryIterator 例項, 這也是屬於 HashMap 的非靜態內部類
*/
public final Iterator<Map.Entry<K,V>> iterator() {
return new EntryIterator();
}
...
}
EntryIterator
/**
* HashMap 的非靜態內部類
*/
final class EntryIterator extends HashIterator
implements Iterator<Map.Entry<K,V>> {
/**
* next 方法呼叫父類 HashIterator 的 nextNode 方法, 返回下一個元素
*/
public final Map.Entry<K,V> next() { return nextNode(); }
}
HashIterator
/**
* HashMap 的內部抽象類
*/
abstract class HashIterator {
Node<K,V> next; // next entry to return
Node<K,V> current; // current entry
int expectedModCount; // for fast-fail
int index; // current slot
/**
* 建構函式, 從 0 開始遍歷 HashMap 的儲存陣列, 一直到非空元素
*/
HashIterator() {
expectedModCount = modCount;
Node<K,V>[] t = table;
current = next = null;
index = 0;
if (t != null && size > 0) { // advance to first entry
do {} while (index < t.length && (next = t[index++]) == null);
}
}
public final boolean hasNext() {
return next != null;
}
final Node<K,V> nextNode() {
Node<K,V>[] t;
Node<K,V> e = next;
if (modCount != expectedModCount)
throw new ConcurrentModificationException();
if (e == null)
throw new NoSuchElementException();
// 從根節點開始遍歷連結串列, 其中樹也當成連結串列結構來遍歷, 一直到尾節點
if ((next = (current = e).next) == null && (t = table) != null) {
// 連結串列遍歷完全後, 重新讀取陣列的下一個非空元素
do {} while (index < t.length && (next = t[index++]) == null);
}
return e;
}
}
以上就是 HashMap 的遍歷方法, 它不是按照插入節點的先後順序進行遍歷, 而是按照陣列結構來遍歷.
相關文章
- HashMap原始碼詳解HashMap原始碼
- 詳解HashMap原始碼解析(下)HashMap原始碼
- 詳解HashMap原始碼解析(上)HashMap原始碼
- HashMap原理詳解,包括底層原理HashMap
- 七. Vue Router詳解Vue
- Java集合詳解(三):HashMap原理解析JavaHashMap
- OSI七層模型詳解模型
- ELK詳解(七)——Kibana部署
- HashMap自動擴容機制原始碼詳解HashMap原始碼
- Flutter 佈局(七)- Row、Column詳解Flutter
- HashMap圖解HashMap圖解
- 詳解Python拼接字串的七種方式Python字串
- Python基礎之七:編碼詳解Python
- OSI七層網路結構詳解
- HashMap稍微詳細的理解HashMap
- Quartz.Net系列(七):Trigger之SimpleScheduleBuilder詳解quartzUI
- 一萬三千字的HashMap面試必問知識點詳解HashMap面試
- HashMap原始碼解讀HashMap原始碼
- HashMap原始碼分析(二):看完徹底瞭解HashMapHashMap原始碼
- 十分鐘快速掌握HashMap底層實現原理(圖文詳解)HashMap
- 設計模式的七大原則詳解設計模式
- Python中的56個內建函式詳解(七)Python函式
- java之HashMap用法講解JavaHashMap
- HashMap之tableSizeFor方法圖解HashMap圖解
- Solon詳解(七)- Solon Ioc 的註解對比Spring及JSR330SpringJS
- Flutter完整開發實戰詳解(七、 深入佈局原理)Flutter
- HashMap中ConcurrentModificationException異常解讀HashMapException
- HashMap原始碼個人解讀HashMap原始碼
- 分散式檔案儲存FastDFS(七)FastDFS配置檔案詳解分散式AST
- 一文精通HashMap靈魂七問,你學還是不學HashMap
- 從零開始手寫 redis(七)LRU 快取淘汰策略詳解Redis快取
- 【Java入門提高篇】Day24 Java容器類詳解(七)HashMaJava
- Java-HashMap中put原始碼解讀JavaHashMap原始碼
- HashMap原始碼解析和設計解讀HashMap原始碼
- Spring系列第七講 自動注入(autowire)詳解,高手在於堅持!Spring
- Java 容器系列(七):HashMap 原始碼分析01之建構函式、內部類JavaHashMap原始碼函式
- 從零學習Fluter(七):Flutter仿boss直聘以及Flutter打包apk詳解FlutterAPK
- windows第七層負載均衡 基於IIS的ARR負載均衡詳解Windows負載