Map key重复则会出现最后一次put的value //HashMap TreeMap
遍历Map
Map<Object, Object> map = new HashMap<Object, Object>();
1.老版本遍历,泛型1.5以上 ,可以进行entry移除的操作
//iterator.remove();
Iterator<Map.Entry<Object, Object>> it = map.entrySet().iterator();
while(it.hasNext()){
Entry<Object, Object> 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<Object, Object> entry:map.entrySet()){
System.out.println("key:"+entry.getKey()+":"+"value"+entry.getValue());
}
4.只进行key或value遍历,视具体情况
Collection<Object> values = map.values();
Set<Object> keySet = map.keySet();
总结:
如果只需要遍历key或value,那采用4方法速度是最快的
除去该种情况,推荐使用3方法,速率相对来说最好
1方法肯定能用
2方法据键取value遍历速率不理想
本文介绍了四种不同的Java Map遍历方法:使用迭代器遍历、使用增强for循环遍历keySet、使用增强for循环遍历entrySet以及仅遍历key或value的方法。并对各种遍历方法的适用场景进行了说明。
905

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



