Map<String, String> map = new HashMap<>();
map.put("01", "java");
map.put("03", "php");
map.put("05", "BigData");
map.put("02", "python");
System.out.println(map);
想要对map进行遍历的时候,有很多种方法选择
//通过Set keySet()
Set<String> set1 = map.keySet();
//获取迭代器
Iterator<String> iterator = set1.iterator();
while (iterator.hasNext()) {
String key = iterator.next();
//再去获取value
System.out.println("key:"+key+" value:"+map.get(key));
}
//Set
//使用foreach
for (Entry entry : map.entrySet()) {
System.out.println("key:"+entry.getKey()+" value:"+entry.getValue());
}
显而易见使用foreach非常的方便,极大提高了效率
既然有了这种简单的方法,谁还会去用迭代器,简直就是有毛病
经过多方调研发现,foreach是一种”语法糖”,所谓语法糖就是通过编译器或者其它手段优化了代码,给使用带来了遍历。也就是,Java给开发者的福利.那么foreach的使用条件是什么呢?
所以,在内部foreach是直接调用了Iterable迭代器,这样我们就可以想象到,如果在foreach中对collection进行遍历的时候,就不能使用collection.remove(),下面就行一些验证:
for (String i : list) {
System.out.println(i);
list.remove(i); //问题出现
}
这里抛出了ConcurrentModificationException
异常
代码如下:
Iterator it=list.iterator();
while (it.hasNext()){
System.out.println(it.next());
it.remove(); // 通过
}
这里使用的是Iterator自带的remove方法.不会出现问题