Java中遍历一个Map的方法
Map<String,String> map = new HashMap<String,String>(){}; 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<Entry<String,String>> entryset = map.entrySet(); Iterator iter = entryset.iterator(); while(iter.hasNext()){ Entry<String,String> entry = (Entry<String,String>)iter.next(); } //第三种 for(Entry<String,String> entry : map.entrySet()){ String strkey = entry.getKey(); String strval = entry.getValue(); } 首先,使用entryset比使用keyset的效率要高。所以建议用后2种方法。 第二和第三种的区别其实就是使用迭代器iteratior和使用一般的for语句的区别,和map本身倒没什么关系。最简单的判断方法,就是对要迭代的内容(本例是个map,如果是一个list同理),在循环过程中,你需要进行add或者remove操作不。for语句的循环是不能做这样的操作的,只能使用迭代器。 不过,个人认为,for语句虽然看上去代码少一点,但敲起来没iterator有感觉
posted on 2012-02-15 01:40 阳光总在风雨后001 阅读(10573) 评论(0) 编辑 收藏 举报