Map集合是Java中非常常用的一個集合,通過Map集合可以實作對資料的快速檢索和插入洗掉等操作;同樣對Map集合的遍歷也是十分重要的;如果你之前學過C++,那么對于Map的遍歷操作可就不能像是C++那樣通過下標遍歷了;
這里我提供兩種遍歷Map集合的方式,以及性能和使用方式的比較;
通過key獲取value
這種方式是先獲取Map的key值,再通過 Map 的 get() 方法 獲取對應的value值;
代碼如下:
import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
import java.util.Set;
public class MapTraverse01 {
public static void main(String[] args) {
Map<Integer, String> map = new HashMap<>(); // 創建一個HashMap物件
// 存入map
map.put(1, "張三");
map.put(2, "李四");
map.put(3, "王五");
map.put(4, "趙六");
map.put(5, "小三");
// 迭代器遍歷
Set<Integer> set = map.keySet(); // 獲取key對應的Set集合
Iterator<Integer> iterator = set.iterator(); // 通過迭代器遍歷
while (iterator.hasNext()) {
Integer i = iterator.next();
// 輸出key并通過key輸出value
System.out.println("key:" + i + " value:" + map.get(i));
}
System.out.println("=================");
// foreach回圈
for (Integer i : map.keySet()) {
System.out.println("key:" + i + " value:" + map.get(i));
}
System.out.println("=================");
}
}
輸出如下:
key:1 value:張三
key:2 value:李四
key:3 value:王五
key:4 value:趙六
key:5 value:小三
=================
key:1 value:張三
key:2 value:李四
key:3 value:王五
key:4 value:趙六
key:5 value:小三
=================
這里我用了迭代器和foreach回圈,至于它們的區別我會在文章最后詳細介紹;
接下來分析一下這種方法的效率;
我們通過 keySet() 方法獲取到了所有的key值,并沒有獲取到value值,這意味著每次遍歷時通過 get() 方法得到value值時都需要再次遍歷Map集合,就相當于遍歷了兩次,第一次是對key的Set集合遍歷,第二次是通過map.get(key)來獲取value值;
一旦資料量大的時候,這種遍歷方式的效率就會明顯降低;
當然,如果資料量較小時還是比較推薦這種方法的;
同時獲取key和Value
這種方法是同時獲取到 key 和 value 值,這里就不再使用 keySet() 方法了,而是使用 entrySet() 獲取Map中的key-value對;
這里還是簡單介紹一下Map.Entry<K,V>介面;
public static interface Map.Entry<K,V>
英語好的可以結合理解一下對Map.Entry<K,V>介面的介紹:
A map entry (key-value pair). The Map.entrySet method returns a collection-view of the map, whose elements are of this class. The only way to obtain a reference to a map entry is from the iterator of this collection-view. These Map.Entry objects are valid only for the duration of the iteration; more formally, the behavior of a map entry is undefined if the backing map has been modified after the entry was returned by the iterator, except through the setValue operation on the map entry.
其中這里我們只需要記住兩種方法:

就是分別獲取到key值和value值;
下面我將用代碼示范一下第二種遍歷方式:
import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
import java.util.Set;
public class MapTraverse02 {
public static void main(String[] args) {
Map<Integer, String> map = new HashMap<>(); // 創建一個HashMap物件
// 存入map
map.put(1, "張三");
map.put(2, "李四");
map.put(3, "王五");
map.put(4, "趙六");
map.put(5, "小三");
// 迭代器
Set<Map.Entry<Integer, String>> set = map.entrySet(); // 獲取map中的key-value對
Iterator<Map.Entry<Integer, String>> iterator = set.iterator();
while (iterator.hasNext()) {
Map.Entry<Integer, String> i = iterator.next();
// 這里必須定義區域變數,如果直接用迭代器獲取key后迭代器就會前移,輸出下一個value時就會到達下一個迭代的位置
// System.out.println("key:" + iterator2.next().getKey() + " value:" + iterator2.next().getValue());
// 上面這樣不可以
// 通過Entry內部類獲取key和value
System.out.println("key:" + i.getKey() + " value:" + i.getValue());
}
System.out.println("=================");
// foreach回圈
for (Map.Entry<Integer, String> i : map.entrySet()) {
System.out.println("key:" + i.getKey() + " value:" + i.getValue());
}
System.out.println("=================");
}
}
輸出如下:
key:1 value:張三
key:2 value:李四
key:3 value:王五
key:4 value:趙六
key:5 value:小三
=================
key:1 value:張三
key:2 value:李四
key:3 value:王五
key:4 value:趙六
key:5 value:小三
=================
這種遍歷方式在資料量大的時候比第一種方式效率更高,因為是同時獲取的key和value值,所以還是要根據實際情況對這兩種遍歷方法進行選擇;
可能開始接觸Map.Entry會有不適應,多用用就好了,以后可能會考慮為Map.Entry專門寫一篇博客,在這里留個位;
迭代器遍歷和foreach遍歷的區別
這里簡單說一下這兩種遍歷方式的區別;
迭代器遍歷的效率會比foreach回圈遍歷的效率高一點,但是它們的主要區別并不在這里;
只需要記住一點:
如果用foreach回圈體,那么對集合元素進行增刪改操作的時候,
就會出現例外ConcurrentModificationException;
所以foreach僅僅用來遍歷輸出還是方便的,但是不要用來修改集合的資料;
如果需要對集合進行增刪改操作,那么就使用迭代器遍歷,可以使用 iterator 的 remove()方法;
這里就不做示范了,感興趣可以自己嘗試;
歡迎大家的點評!
轉載請註明出處,本文鏈接:https://www.uj5u.com/ruanti/357162.html
標籤:其他
