美文网首页
LinkedHashMap

LinkedHashMap

作者: 梦想家图图图 | 来源:发表于2016-10-27 17:37 被阅读0次

1.LinkedHashMap继承了HashMap并实现了Map接口

public class LinkedHashMap<K,V>    extends HashMap<K,V>    implements Map<K,V>

1.1LinkedHashMap中的元素变量

//双向链表的头结点
private transient Entry<K,V> header;
//true:最近最少使用次序
//false:表示遍历的时候根据插入的顺序
private final boolean accessOrder;

1.2LinkedHashMap的构造函数

//设置容量和加载因子
public LinkedHashMap(int initialCapacity, float loadFactor);
//只设置初始容量
public LinkedHashMap(int initialCapacity) ;
//使用默认值
public LinkedHashMap();

1.3LinkedHashMap是如何确认有序的

我们来看下节点代码的改动**

private static class Entry<K,V> extends HashMap.Entry<K,V> {
        Entry<K,V> before, after;

        Entry(int hash, K key, V value, HashMap.Entry<K,V> next) {
            super(hash, key, value, next);
        }

        private void remove() {
            before.after = after;
            after.before = before;
        }

        private void addBefore(Entry<K,V> existingEntry) {
            after  = existingEntry;
            before = existingEntry.before;
            before.after = this;
            after.before = this;
        }
        
        void recordAccess(HashMap<K,V> m) {
            LinkedHashMap<K,V> lm = (LinkedHashMap<K,V>)m;
            if (lm.accessOrder) {
                lm.modCount++;
                remove();
                addBefore(lm.header);
            }
        }
        void recordRemoval(HashMap<K,V> m) {
            remove();
        }
    }

相关文章

网友评论

      本文标题:LinkedHashMap

      本文链接:https://www.haomeiwen.com/subject/bplsuttx.html