Java Map的几种遍历方法

Map key重复则会出现最后一次put的value //HashMap TreeMap

 

遍历Map


Map map = new HashMap();

 

 

1.老版本遍历,泛型1.5以上 ,可以进行entry移除的操作

 

//iterator.remove();
Iterator> it = map.entrySet().iterator();
while(it.hasNext()){
    Entry entry = it.next();
    System.out.println("key:"+entry.getKey()+":"+"value"+entry.getValue());
}

 

 

 

2. 1.5以上

for(Object key:map.keySet()){
    System.out.println("key:"+key+":"+"value"+map.get(key));
}

 

 

3.EntrySet遍历

for(Map.Entry entry:map.entrySet()){
    System.out.println("key:"+entry.getKey()+":"+"value"+entry.getValue());
}

 

 

4.只进行key或value遍历,视具体情况

Collection values = map.values();
Set keySet = map.keySet(); 
  

 

 

 

总结:

如果只需要遍历key或value,那采用4方法速度是最快的
除去该种情况,推荐使用3方法,速率相对来说最好
1方法肯定能用
2方法据键取value遍历速率不理想

 

 

你可能感兴趣的:(Java)