map的四种遍历方式

map是Java中非常常用的一种数据结构,但map不同于set和list都继承自Collection接口。

所以map没有实现Collection的Iterator 方法,自身没有迭代器来遍历元素。

构造一个map

  1. Map<String, String> map = new HashMap<String, String>();
  2. map.put("001", "hello");
  3. map.put("002", "world");
  4. map.put("003", "main");

想遍历这个map,那map通常的遍历方式有哪几种呢?

这里我们介绍常用的四种方式:keySet集合迭代,entrySet集合迭代,keySet 集合for-each 循环,entrySet集合for-each循环。

方法1 keySet集合迭代

  1. // method1
  2. Set<String> keySet = map.keySet();
  3. Iterator<String> it = keySet.iterator();
  4. while (it.hasNext()) {
  5. String key = it.next();
  6. System.out.println(key + "=" + map.get(key));
  7. }

方法2 entrySet集合迭代

  1. // method2
  2. Set<Map.Entry<String, String>> entrySet = map.entrySet();
  3. Iterator<Map.Entry<String, String>> meIt = entrySet.iterator();
  4. while (meIt.hasNext()) {
  5. Entry<String, String> entry = meIt.next();
  6. System.out.println(entry.getKey() + "=" + entry.getValue());
  7. }

方法3 keySet集合for-each循环

  1. // method3
  2. for (String key : map.keySet()) {
  3. System.out.println(key + "=" + map.get(key));
  4. }

方法4 entrySet集合for-each循环

  1. // method4
  2. for (Map.Entry<String, String> entry : map.entrySet()) {
  3. System.out.println(entry.getKey() + "=" + entry.getValue());
  4. }

四种方式中,method1 和 method2 是通过迭代器来显示完成的,method3 和 method4 是通过for-each来隐式的通过迭代器来完成的。

同时 method1 和 method3 是通过key的集合来完成的,method2 和 method4 是通过entry 的集合来完成的。

方法1 和方法2 的区别

一个是获取keySet ,一个是获取entrySet

推荐使用entrySet 的方式去获取,查看map通过key获取value的方法

  1. public V get(Object key) {
  2. if (key == null)
  3. return getForNullKey();
  4. Entry<K,V> entry = getEntry(key);
  5. return null == entry ? null : entry.getValue();
  6. }

也是先获取该key对应的entry,然后再获取value值,所以,推荐使用entrySet 方法,再遍历entry集合的方式来遍历map

map 接口还有一个方法 values() ,由于仅能取到所有的value值,而取不到key值,所以在这里就算不上遍历map了,只能算上遍历map的value值。

上一篇:SPOJ 416 - Divisibility by 15(贪心)


下一篇:Map的四种遍历