LinkedHashMap 源码解析

HashMap使用哈希表来存储数据,并用拉链法来处理冲突。

1. 关于容量的问题,使用2的幂方

如果给定Map一个初始容量,但看构造器里,会寻找比这个初始值大的2的幂方

// Find a power of 2 >= initialCapacity
int capacity = 1;
while (capacity < initialCapacity)
    capacity <<= 1;

所以在寻找Hash位置的时候,可以直接利用位运算。

// Returns index for hash code h.

static int More ...indexFor(int h, int length) {
    return h & (length-1);
}

私有类class Entry<K,V> extends HashMap.Entry<K,V>

// 这是一个私有的、静态的内部类,继承自HashMap的Entry。
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);
    }

    // 移除该节点,只需修改前一节点的after引用和后一节点的before引用
private void remove() {
    // 修改后该节点服务再被访问,会被GC回收
        before.after = after;
        after.before = before;
    }

    // 在指定节点之前插入当前节点(双向链表插入节点的过程)
private void addBefore(Entry<K,V> existingEntry) {
    // 将当前节点的after引用指向existingEntry
        after  = existingEntry;
        // 将before的引用指向existingEntry节点的前一节点
before = existingEntry.before;
        // 将原先existingEntry节点的前一节点的after引用指向当前节点
before.after = this; 
        // 将原先existingEntry节点的后一节点的before引用指向当前节点
        after.before = this;
    }

//remove();加addBefore(lm.header);可以将元素移动到header之前
// 
    void recordAccess(HashMap<K,V> m) {
        LinkedHashMap<K,V> lm = (LinkedHashMap<K,V>)m;
        if (lm.accessOrder) {
            lm.modCount++;
            remove();
            addBefore(lm.header);
        }
    }
    // 和recordAccess(HashMap<K.V> m)方法一样,在HashMap.Entry中同样有一个对应的空方法。当进行删除(remove)操作的时候会被调用
    void recordRemoval(HashMap<K,V> m) {
        remove();
    }
}

int expectedModCount; // For fast-fail

剖析LRU算法及LinkedHashMap源码实现机制

http://docs.oracle.com/javase/7/docs/api/java/util/LinkedHashMap.html

http://grepcode.com/file/repository.grepcode.com/java/root/jdk/openjdk/6-b14/java/util/LinkedHashMap.java

HashMap源码分析(基于JDK1.6)

LinkedHashMap源码分析(基于JDK1.6)

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值