不像实现了Collection接口的List和set,可以直接使用增强for循环(T t: collections)或者Iterator的hasNext和next进行遍历。map的遍历需要一些额外的操作,map虽然没有继承自Collection,但是entryset是Set接口的实现类。
遍历的核心思路是利用下面的三个方法。
maps.entrySet();
maps.keySet();
maps.values();
PS:任何集合在遍历时要进行删除操作时都需要使用迭代器。
方法一:借助SET的特性,在for-each循环中使用entry来遍历
这是最常见的并且在大多数情况下也是最可取的遍历方式。在键值都需要时使用。
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());
}
方法二 在for-each循环中遍历keys或values。
如果只需要map中的键或者值,你可以通过keySet或values来实现遍历,而不是用entrySet。
Map<Integer, Integer> map = new HashMap<Integer, Integer>();
//遍历map中的键
for (Integer key : map.keySet()) {
System.out.println("Key = " + key);
}
//遍历map中的值
for (Integer value : map.values()) {
System.out.println("Value = " + value);
}
方法三 使用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<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实现中该方法慢了20%~200%)。如果你安装了FindBugs,它会做出检查并警告你关于哪些是低效率的遍历。所以尽量避免使用。
本文介绍了Java中Map遍历的四种常见方法:通过entrySet、keySet和values进行遍历,以及使用Iterator。强调在遍历过程中进行删除操作时需使用Iterator。详细对比了不同遍历方式的适用场景和效率,特别是指出通过键找值遍历的方式效率较低。
193

被折叠的 条评论
为什么被折叠?



