如何保证LinkedHashMap以及它实现LRU缓存线程安全

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档


线程安全的 LinkedHashMap

我这里花几分钟时间聊一下这个问题。

通过阅读我前面的文章,我们知道:
HashMap 有一个问题,就是迭代 HashMap 的顺序并不是 HashMap 放置的顺序,也就是无序。HashMap 的这一缺点往往会带来困扰,因为有些场景,我们期待一个有序的 Map。

这个时候,LinkedHashMap 就闪亮登场了,它虽然增加了时间和空间上的开销,但是通过维护一个运行于所有条目的双向链表,LinkedHashMap 保证了元素迭代的顺序。该迭代顺序可以是插入顺序或者是访问顺序。

在这里插入图片描述

LinkedHashMap面试点

LinkedHashMap 可以认为是 HashMap + LinkedList,即它既使用 HashMap 操作数据结构,又使用 LinkedList 维护插入元素的先后顺序。

上面帮助大家简单回顾了一下 LinkedHashMap 后,接下来,我们再来看看如何把 LinkedHashMap 变得线程安全。

最佳答案就是我们可以匿名扩展 LinkedHashMap 来更改 removeEldestEntry(…) 的行为,然后将匿名类的实例包装在同步映射中。

Map<String, Integer> map = Collections.synchronizedMap(new LinkedHashMap<String,
  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值