https://blog.csdn.net/qq_21815981/article/details/80622812
https://www.cnblogs.com/fqfanqi/p/6187085.html
获取map的key和value的方法分为三种形式(前两种都有各自的迭代器):
map.keySet():先获取map的key,然后根据key获取对应的value / 或者单独获取 key;map.entrySet():同时查询map的key和value,只需要查询一次。map.values():单独获取 value同时遍历key和value时,keySet与entrySet方法的性能差异取决于key的具体情况,如复杂度(复杂对象)、离散度、冲突率等。换言之,取决于HashMap查找value的开销。
entrySet一次性取出所有key和value的操作是有性能开销的,当这个损失小于HashMap查找value的开销时,entrySet的性能优势就会体现出来。 只遍历key时,keySet方法更为合适,因为entrySet将无用的value也给取出来了,浪费了性能和空间。 只遍历value时,使用vlaues方法是最佳选择,entrySet会略好于keySet方法。======================
使用泛型:
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 map = new HashMap(); Iterator entries = map.entrySet().iterator(); while (entries.hasNext()) { Map.Entry entry = (Map.Entry) entries.next(); Integer key = (Integer)entry.getKey(); Integer value = (Integer)entry.getValue(); System.out.println("Key = " + key + ", Value = " + value); }你也可以在 keySet 和 values上应用同样的方法。
该种方式看起来冗余却有其优点所在。
首先,在老版本java中这是惟一遍历map的方式。其次,你可以在遍历时调用iterator.remove()来删除entries,另两个方法则不能。根据javadoc的说明,如果在for-each遍历中尝试使用此方法,结果是不可预测的。