Map map = new HashMap(){};
map.put("a", "A");
map.put("b", "B");
map.put("c", "C");
//第一种
Set set = map.keySet();
Iterator it = set.iterator();
while(it.hasNext()){
String str = it.next().toString();
}
//第二种
Set> entryset = map.entrySet();
Iterator iter = entryset.iterator();
while(iter.hasNext()){
Entry entry = (Entry)iter.next();
}
//第三种
for(Entry entry : map.entrySet()){
String strkey = entry.getKey();
String strval = entry.getValue();
}
首先,使用entryset比使用keyset的效率要高。所以建议用后2种方法。
第二和第三种的区别其实就是使用迭代器iteratior和使用一般的for语句的区别,和map本身倒没什么关系。最简单的判断方法,就是对要迭代的内容(本例是个map,如果是一个list同理),在循环过程中,你需要进行add或者remove操作不。for语句的循环是不能做这样的操作的,只能使用迭代器。
不过,个人认为,for语句虽然看上去代码少一点,但敲起来没iterator有感觉