Set s = HashMap.keySet()
-------------->>>>>>>>>>>
Iterator it = s.iterator();
while(it.hasNext())
System.out.println(m.get(it.next()));
不能保持插入HashMap的顺序输出
----------->>>>>>>>>>>
for(Integer i : s)
System.out.println(m.get(i));
可以保持插入顺序输出
上面一段伪代码,一个是通过HashMap的keySet()方法得到一个键集合,再在键集合上迭代,输出HashMap的值,不能保持插入HashMap顺序输出
另一个通过java 5.0的新特性 for(:)循环输出HashMap的值,就能保持插入序输出,
为什么呢?谁能解释一下 for(:)运行机制,谢谢
[b]问题补充:[/b]
我用的HashMap键是 Integer型 值是String型的,而且HashMap的中元素要多一些,我用的测试用例有22个键值对,前13行保持插入序,而13行以后就乱序了,
还有增强的for(:)循环是将第二个操作数转化为数组实现,还是迭代器实现呢?
[b]问题补充:[/b]
发现了,是我测试用例的问题,增强for循环的方法和迭代器的方法都会乱序输出,增强for也是用的迭代器实现,如果要保持插入顺序,应该用LinkedHashMap类,呵呵,谢谢大家
jdk1.5的增强for循环, 如果是Collection, 调用的正是iterator()方法.
在上面的例子中, 调用的都是 Set soo 的 soo.iterator() 方法.
所以, LZ的结论错了, aidiyuxin说对了: 两个方法是一样的结果.
如果用for(int i = 0 ; i < s i++)遍历呢?
测试例子
[code="java"]Map moo = new HashMap();
moo.put("1","1");
moo.put("2","2");
moo.put("3","3");
Set soo = moo.keySet();
Iterator ioo = soo.iterator();
while(ioo.hasNext()){
System.out.println(moo.get(ioo.next()));
}
for(String str : soo){
System.out.println(moo.get(str));
}[/code]
结果:
[code="java"]
3
2
1
3
2
1[/code]
没有什么特殊的地方啊