黑马程序员技术交流社区
标题:
HashMap的迭代
[打印本页]
作者:
希望多多
时间:
2014-3-14 16:27
标题:
HashMap的迭代
本帖最后由 希望多多 于 2014-3-14 16:55 编辑
下面是一段Map的代码:
public void test(){Map map=new HashMap();
map.put(1,"aa");
map.put(2,"bb");
map.put(3,"cc");
//取值
for(Object obj:map.entrySet()){
Map.Entry entry1=(java.util.Map.Entry) obj;
String key=(String) entry1.getKey();
String value=(String) entry1.getValue();
System.out.println(key+" = "+value);
}
}
取出来的值不是按照放入的顺序显示的,那么如何是取出的值的顺序与放入的顺序一样呢?
作者:
菠萝鱼
时间:
2014-3-14 16:37
用 LinkedHashMap 存放。
作者:
daoyua
时间:
2014-3-14 16:37
首先,hashmap的序列是按照哈希值排列的,hash一般你不知道的,所以是无序的,你如果重写hashcode函数,把hash值修改了,就可以达到你存入什么顺序,取出就是什么顺序
作者:
daoyua
时间:
2014-3-14 16:38
不过一般遇到这种情况,你可以Treemap啊,默认是自然排序,就可以存什么,取什么了
作者:
希望多多
时间:
2014-3-14 16:55
菠萝鱼 发表于 2014-3-14 16:37
用 LinkedHashMap 存放。
确实,用LinkedHashMap存放可以解决这个问题,谢了啊
欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/)
黑马程序员IT技术论坛 X3.2