LinkedHashMap 源码解析
来源:互联网 发布:域名别名设置 编辑:程序博客网 时间:2024/04/29 23:38
HashMap使用哈希表来存储数据,并用拉链法来处理冲突。
1. 关于容量的问题,使用2的幂方
如果给定Map一个初始容量,但看构造器里,会寻找比这个初始值大的2的幂方
// Find a power of 2 >= initialCapacityint 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
- LinkedHashMap 源码解析
- LinkedHashMap源码解析
- LinkedHashMap源码解析
- LinkedHashMap源码解析
- LinkedHashMap源码解析
- LinkedHashMap源码解析
- java LinkedHashMap源码解析
- Java LinkedHashMap源码解析
- LinkedHashMap源码解析
- LinkedHashMap类源码解析
- LinkedHashMap源码解析
- LinkedHashMap源码解析
- LinkedHashMap 源码解析
- LinkedHashMap源码解析
- d.linkedhashMap源码解析(1.7)
- JDK之LinkedHashMap源码解析
- java.util.LinkedHashMap源码解析
- java 源码解析(02) LinkedHashMap
- Server ran out of threads to serve requests. Consider raising the ThreadsPerChild setting的解决方法
- 深入分析基于VCL派生的ActiveX控件的实现原理及应用
- 介绍一些有助于写出更好Go程序的工具
- 用中科院ICTCLAS2015分词器的java接口
- leetcode invert-binary-tree
- LinkedHashMap 源码解析
- POJ-1338-暴力水题
- Java单向(非可逆)加密--MD5、SHA和HMAC
- 没有躲过的坑--意想不到的除数为零
- linux内核中的.config
- 确定了转到java上面
- cd
- 在C++中使用GOLANG的协程
- vs已停止工作的解决方案