java Map 怎么遍历

Python060

java Map 怎么遍历,第1张

关于java中遍历map具体有四种方式,请看下文详解。

1、这是最常见的并且在大多数情况下也是最可取的遍历方式,在键值都需要时使用。

Map<Integer, Integer>map = new HashMap<Integer, Integer>()

for (Map.Entry<Integer, Integer>entry : map.entrySet()) {

System.out.println("Key = " + entry.getKey() + ", Value = " + entry.getValue())

}

2、在for-each循环中遍历keys或values。

如果只需要map中的键或者值,你可以通过keySet或values来实现遍历,而不是用entrySet。

Map<Integer, Integer>map = new HashMap<Integer, Integer>()

for (Integer key : map.keySet()) {

System.out.println("Key = " + key)

}

for (Integer value : map.values()) {

System.out.println("Value = " + value)

}

方法比entrySet遍历在性能上稍好(快了10%),而且代码更加干净。

3、使用Iterator遍历

使用泛型:

Map<Integer, Integer>map = new HashMap<Integer, Integer>()

Iterator<Map.Entry<Integer, Integer>>entries = map.entrySet().iterator()

while (entries.hasNext()) {

Map.Entry<Integer, Integer>entry = entries.next()

System.out.println("Key = " + entry.getKey() + ", Value = " + entry.getValue())

}

不使用泛型:

Map map = new HashMap()

Iterator entries = map.entrySet().iterator()

while (entries.hasNext()) {

Map.Entry entry = (Map.Entry) entries.next()

Integer key = (Integer)entry.getKey()

Integer value = (Integer)entry.getValue()

System.out.println("Key = " + key + ", Value = " + value)

}

4、通过键找值遍历(效率低)

Map<Integer, Integer>map = new HashMap<Integer, Integer>()

for (Integer key : map.keySet()) {

Integer value = map.get(key)

System.out.println("Key = " + key + ", Value = " + value)

}

假设Map中的键值对为1=>11,2=>22,3=>33,现用方法1来遍历Map代码和调试结果如下:

扩展资料:

1、HashMap的重要参数

HashMap 的实例有两个参数影响其性能:初始容量 和加载因子。容量是哈希表中桶的数量,初始容量只是哈希表在创建时的容量。

加载因子 是哈希表在其容量自动增加之前可以达到多满的一种尺度。当哈希表中的条目数超出了加载因子与当前容量的乘积时,则要对该哈希表进行 rehash 操作(即重建内部数据结构),从而哈希表将具有大约两倍的桶数。

在Java编程语言中,加载因子默认值为0.75,默认哈希表元为101。

2、HashMap的同步机制

注意,此实现不是同步的。 如果多个线程同时访问一个哈希映射,而其中至少一个线程从结构上修改了该映射,则它必须保持外部同步。

(结构上的修改是指添加或删除一个或多个映射关系的任何操作;以防止对映射进行意外的非同步访问,如下:

Map m = Collections.synchronizedMap(new HashMap(...))

参考资料:百度百科-Hashmap

Java中遍历Map对象的4种方法:

1、通过Map.entrySet遍历key和value,在for-each循环中使用entries来遍历.推荐,尤其是容量大时。

2、通过Map.keySet遍历key,通过键找值value遍历(效率低),普遍使用,二次取值。

3、如果只需要map中的键或者值,你可以通过Map.keySet或Map.values来实现遍历,而不是用entrySet。在for-each循环中遍历keys或values。

4、通过Map.entrySet使用iterator遍历key和value。

扩展资料:

关于JAVA的遍历知识补充:

1、list和set集合都实现了Iterable接口,所以他们的实现类可以使用迭代器遍历,map集合未实现该接口,若要使用迭代器循环遍历,需要借助set集合。

2、使用EntrySet 遍历,效率更高。

参考资料:

百度百科--Map(映射)

常见的Map遍历有下面四种方法:

import java.util.HashMap

import java.util.Iterator

import java.util.Map.Entry

public class MapDemo {

public static void main(String[] args) {

// 准备好需要遍历的Map

HashMap<String, Integer> map = new HashMap<String, Integer>()

map.put("Tom", 85)

map.put("Jack", 97)

test1(map)

test2(map)

test3(map)

test4(map)

}

// 方法一: 迭代器方式

// 特点: 效率高,速度快,但是代码量多

public static void test1(HashMap<String, Integer> map) {

Iterator<Entry<String, Integer>> it = map.entrySet().iterator()

while (it.hasNext()) {

Entry<String, Integer> e = it.next()

System.out.println("name:" + e.getKey() + "\tscore:" + e.getValue())

}

}

// 方法二: map.entrySet() for循环

// 特点: 效率也较高,速度较快,且写法比方法一简单 

public static void test2(HashMap<String, Integer> map) {

for (Entry<String, Integer> e : map.entrySet()) {

System.out.println("name:" + e.getKey() + "\tscore:" + e.getValue())

}

}

// 方法3 map.keySet for循环

// 特点:效率较慢

public static void test3(HashMap<String, Integer> map) {

for (String key : map.keySet()) {

System.out.println("name:" + key + "\tscore:" + map.get(key))

}

}

// 方法四: forEach 

// 特点 速度较慢,但是代码少,简洁 (需要Java8或以上版本的支持)

public static void test4(HashMap<String, Integer> map) {

map.forEach((k, v) -> System.out.println("name:" + k + "\tscore:" + v))

}

}

四种方法之间的效率比较

(test1≈test2)>(test3≈test4)

推荐: 数据量特别大的时候 使用方法1 : 代码长,但是效率高

数据量较少的, 那么使用方法4: 代码简洁而优雅~