5.Java容器-LinkedHashMap

LinkedHashMap概述

       LinkedHashMap是HashMap的子类,内部使用双向链表进行顺序的维护,内部类Entry为HashMap的Node的子类;

       底层是散列表和双向链表,插入的顺序是有序的(底层链表致使有序),和HashMap一样,允许key和value为null,初始容量和装载因子对LinkedHashMap的性能影响很大;也是非同步的,也可以调用Collections的synchronizedMap方法使之具有线程安全的能力;


底层数据结构

构造函数

       如果accessOrder为true,那么表示将顺序记录为访问顺序,否则为插入顺序,默认为false(即,LinkedHashMap默认使用的是插入顺序);

       而正是这一参数并对removeEldestEntry方法进行覆盖便可以快速实现一个简单的LRU缓存;

public LinkedHashMap(int initialCapacity, float loadFactor, boolean accessOrder) {
    super(initialCapacity, loadFactor);
    this.accessOrder = accessOrder;
}

        LinkedHashMap有5个构造方法:



LinkedHashMap的域

LinkedHashMap重写的方法

        下面的是两个比较重要的;

       这就印证了我们的LinkedHashMap底层确确实实是散列表和双向链表:在构建新节点时,构建的是LinkedHashMap.Entry 不再是Node;

put方法

       put方法就是HashMap的put方法,在HashMap部分也提到了afterNodeAccess和afterNodeInsertion方法其实是空实现,而在LinkedHashMap中对其进行了实现,Linked的特性也是在这里进行了体现;


//LinkedhHashMap对此方法进行了覆盖
Node<K,V> newNode(int hash, K key, V value, Node<K,V> e) {
    LinkedHashMap.Entry<K,V> p = new LinkedHashMap.Entry<K,V>(hash, key, value, e);
    linkNodeLast(p);
    return p;
}
//linkNodeLast方法负责双链表的连接:
private void linkNodeLas
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值