java 高效遍历map_精髓!Java中遍历Map集合的五种方式
在java中所有的map都實(shí)現(xiàn)了Map接口,因此所有的Map都可以用以下的方式去遍歷。這篇文章主要給大家介紹了關(guān)于Java中遍歷Map集合的5種方式,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面一起學(xué)習(xí)學(xué)習(xí)吧。
方式一 通過(guò) Map.keySet 使用 iterator 遍歷@Test
public void testHashMap1() {
Map map = new HashMap<>();
map.put(001, "Java");
map.put(002, "數(shù)據(jù)庫(kù)");
map.put(003, "Vue");
System.out.println(map);
Iterator iterator = map.keySet().iterator();
while (iterator.hasNext()) {
Integer key = iterator.next();
String value = map.get(key);
System.out.println("key = " + key + ", value = " + value);
}
}
結(jié)果:{1=Java, 2=數(shù)據(jù)庫(kù), 3=Vue}
key = 1, value = Java
key = 2, value = 數(shù)據(jù)庫(kù)
key = 3, value = Vue
方式二 通過(guò) Map.entrySet 使用 iterator 遍歷@Test
public void testHashMap2() {
Map map = new HashMap<>();
map.put(001, "Java");
map.put(002, "數(shù)據(jù)庫(kù)");
map.put(003, "Vue");
System.out.println(map);
Iterator> entries = map.entrySet().iterator();
while (entries.hasNext()) {
Map.Entry entry = entries.next();
System.out.println(entry);
}
}
結(jié)果:{1=Java, 2=數(shù)據(jù)庫(kù), 3=Vue}
1=Java
2=數(shù)據(jù)庫(kù)
3=Vue
方式三 通過(guò) Map.keySet 遍歷@Test
public void testHashMap3() {
Map map = new HashMap<>();
map.put(001, "Java");
map.put(002, "數(shù)據(jù)庫(kù)");
map.put(003, "Vue");
System.out.println(map);
for (Integer key : map.keySet()) {
System.out.println("key = " + key + ", value = " + map.get(key));
}
}
結(jié)果:{1=Java, 2=數(shù)據(jù)庫(kù), 3=Vue}
key = 1, value = Java
key = 2, value = 數(shù)據(jù)庫(kù)
key = 3, value = Vue
方式四 通過(guò) For-Each 迭代 entries,使用 Map.entrySet 遍歷@Test
public void testHashMap4() {
Map map = new HashMap<>();
map.put(001, "Java");
map.put(002, "數(shù)據(jù)庫(kù)");
map.put(003, "Vue");
System.out.println(map);
for (Map.Entry entry : map.entrySet()) {
System.out.println("key = " + entry.getKey() + ", value = " + entry.getValue());
}
}{1=Java, 2=數(shù)據(jù)庫(kù), 3=Vue}
key = 1, value = Java
key = 2, value = 數(shù)據(jù)庫(kù)
key = 3, value = Vue
方式五 使用 lambda 表達(dá)式 forEach 遍歷@Test
public void testHashMap5() {
Map map = new HashMap<>();
map.put(001, "Java");
map.put(002, "數(shù)據(jù)庫(kù)");
map.put(003, "Vue");
System.out.println(map);
map.forEach((k, v) -> System.out.println("key = " + k + ", value = " + v));
}
forEach 源碼default void forEach(BiConsumer super K, ? super V> action) {
Objects.requireNonNull(action);
for (Map.Entry entry : entrySet()) {
K k;
V v;
try {
k = entry.getKey();
v = entry.getValue();
} catch(IllegalStateException ise) {
throw new ConcurrentModificationException(ise);
}
action.accept(k, v);
}
}
從源碼可以看到,這種新特性就是在傳統(tǒng)的迭代方式上加了一層殼,但是讓代碼變得更加簡(jiǎn)單。(開(kāi)發(fā)中推薦使用)
總結(jié)
推薦使用 entrySet 遍歷 Map 類集合 KV (文章中的第四種方式),而不是 keySet 方式進(jìn)行遍歷。keySet 其實(shí)是遍歷了 2 次,第一次是轉(zhuǎn)為 Iterator 對(duì)象,第二次是從 hashMap 中取出 key 所對(duì)應(yīng)的 value 值。而 entrySet 只是遍歷了一次,就把 key 和 value 都放到了 entry 中,效率更高。
values() 返回的是 V 值集合,是一個(gè) list 集合對(duì)象;keySet() 返回的是 K 值集合,是一個(gè) Set 集合對(duì)象;entrySet() 返回的是 K-V 值組合集合。
如果是 JDK8,推薦使用Map.forEach 方法(文章中的第五種方式)。
由于水平有限,本博客難免有不足,懇請(qǐng)各位大佬不吝賜教!
推薦閱讀
總結(jié)
以上是生活随笔為你收集整理的java 高效遍历map_精髓!Java中遍历Map集合的五种方式的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: 音视频基础知识大全
- 下一篇: Mysql 语法执行顺序