java hashMap和linkedMap的区别

HashMap是无序的,HashMap在put的时候是根据key的hashcode进行hash然后放入对应的地方。所以在按照一定顺序put进HashMap中,然后遍历出HashMap的顺序跟put的顺序不同(除非在put的时候key已经按照hashcode排序号了,这种几率非常小)

单纯的HashMap是无法实现排序的,这的排序是指,我们将键值对按照一定的顺序put进HashMap里,然后在进行取键值对的操作的时候,是按照put进去的顺序把键值对取出来的。

JAVA在JDK1.4以后提供了LinkedHashMap来帮助我们实现了有序的HashMap

LinkedHashMap取键值对时,是按照你放入的顺序来取的。

EG:

import java.util.HashMap;

import java.util.Iterator;

import java.util.LinkedHashMap;

import java.util.Map;

import java.util.Map.Entry;

/**

 * @author TEANA E-mail: mmz06@163.com

 * @version 创建时间:2011-1-21 下午02:23:07

 * @DO       LinkedHashMap与HashMap 

 */

public class LinkedMap

{

    public static void main(String[] args)

    {

        //LinkedHashMap 有序

        Map maps = new LinkedHashMap();

        maps.put("1", "张三");

        maps.put("2", "李四");

        maps.put("3", "王五");

        maps.put("4", "赵六");

        System.out.println("LinkedHashMap(有序):");

        Iterator it = maps.entrySet().iterator();

        while(it.hasNext())

        {

            Map.Entry entity = (Entry) it.next();

            System.out.println("[ key = " + entity.getKey() +

                    ", value = " + entity.getValue() + " ]");

        }

        //HashMap 无序

        Map map = new HashMap();

        map.put("1", "张三");

        map.put("2", "李四");

        map.put("3", "王五");

        map.put("4", "赵六");

        it = null;

        System.out.println("HashMap(无序):");

        it = map.entrySet().iterator();

        while(it.hasNext())

        {

            Map.Entry entity = (Entry) it.next();

            System.out.println("[ key = " + entity.getKey() +

                    ", value = " + entity.getValue() + " ]");

        }

    }

}

执行结果如下:

LinkedHashMap(有序):

[ key = 1, value = 张三 ]

[ key = 2, value = 李四 ]

[ key = 3, value = 王五 ]

[ key = 4, value = 赵六 ]

HashMap(无序):

[ key = 3, value = 王五 ]

[ key = 2, value = 李四 ]

[ key = 1, value = 张三 ]

[ key = 4, value = 赵六 ]

转载于:https://my.oschina.net/qimhkaiyuan/blog/783579

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值