LinkedHashMap底层源码分析(JDK1.8)

1、LinkedHashMap

在这里插入图片描述
LinkedHashMap直接继承自HashMap,底层仍然是数组+链表+红黑树的结构,重写了HashMap的get、remove、foreach等方法。
LinkedHashMap.Entry继承自HashMap.Node,增加了属性before和after,增加了一些双链表相关的操作。从下图中可以看出HashMap.Node、LinkedHashMap.Entry与HashMap.TreeNode之间的关系。
在这里插入图片描述

2、插入顺序与访问顺序

遍历时默认按照插入时的顺序输出

	@Test
    public void testLinkedHashMap(){
        Map<String, Integer> linkedHashMap = new LinkedHashMap<>();
        linkedHashMap.put("a", 1);
        linkedHashMap.put("d", 2);
        linkedHashMap.put("b", 3);
        System.out.println(linkedHashMap);
    }

在这里插入图片描述
可通过属性accessOrder修改为访问顺序输出,也就是最近访问的key会更新到双链表尾部,使其满足LRU(Least Recently Used,最近最少使用)的特性。

    @Test
    public void testLinkedHashMap2(){
        Map<String, Integer> linkedHashMap = new LinkedHashMap<>(3, 0.75f, true);
        linkedHashMap.put("a", 1);
        linkedHashMap.put("d", 2);
        linkedHashMap.put("b", 3);
        linkedHashMap.put("c", 4);
        System.out.println("original map: "+linkedHashMap);
        linkedHashMap.get("a");
        System.out.println("after access a: "+linkedHashMap);
    }

在这里插入图片描述

3、使用LinkedHashMap实现LRU

继承LinkedHashMap并重写removeEldestEntry方法。
参考
参考

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值