黑马程序员技术交流社区

标题: 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