提要

Java遍历hashmap 总是要查找 Map.Entry<Integer,Integer> entry : map.entrySet(),总是记不住,索性就看一遍源码

Map.Entry简介

Map是java中的接口,Map.Entry是Map的一个内部接口。

Map提供了一些常用方法,如keySet()、entrySet()等方法,keySet()方法返回值是Map中key值的集合;entrySet()的返回值也是返回一个Set集合,此集合的类型为Map.Entry。

Map.Entry是Map声明的一个内部接口,此接口为泛型,定义为Entry<K,V>。它表示Map中的一个实体(一个key-value对)。接口中有getKey(),getValue方法。

从entrySet()方法解释Map.Entry

set<Map,Entry<K,V>> entrySet() 将Map集合转换成set集合
假设现在有一个Map集合,如下所示
map集合

key value
 1 zhangsan
 2 lisi
 3 wangwu
 4 zhaoliu
 Set set=map1.entrySet();


set集合对象****中的每个元素都是Entry键值对

1=zhangsan
 2=lisi
 3=wangwu
 4=zhaoliu

注意:Map集合通过entrySet()方法转换成的这个set集合,set集合中元素的类型是Map.Entry<K,V>
Map.Entry和String一样,都是一种类型的名字,只不过Map.entry是静态内部类,是Map中的

我们可以深入HashMap的源码中看到

static class Node<K,V> implements Map.Entry<K,V> {
        final int hash;
        final K key;
        V value;
        Node<K,V> next;

Node<K,V>实现了Entry接口,Entry接口中K表示key,即键,V表示value,即值。Entry即Node是Map集合中的一个对象元素,而Map集合正是由一个个Entry即Node对象所构成。
正是因为Node实现了Entry接口,所以使用Entry的时候也可以使用其getValue()和getKey()方法
具体结构如图所示:

  1. 使用Map.Entry遍历Map集合
public static void main(String[] args) {
    Map<Integer,String> maps=new HashMap<Integer,String>();
    maps.put(3,"张飞");
    maps.put(2,"关羽");
    maps.put(4,"赵云");
    maps.put(1,"刘备");
    maps.put(5,"马超");
    Set<Map.Entry<Integer,String>> sets=maps.entrySet();
    for(Map.Entry<Integer,String> entry:sets){
        System.out.println("key="+entry.getKey()+" value="+entry.getValue());
    }
}