一、概述
- WeekHashMap区别于HashMap,在于key值都为弱引用。
- Java将引用分为四类,强度依次逐渐减弱:
- 强引用: 就是平常使用的普通引用对象,例如Object obj = new Object(),这就是一个强引用,强引用只要还存在,就不会被垃圾收集器回收。
- 软引用: 通过SoftReference类来间接引用目标对象。软引用表示一个还有用但并非必需的对象。被软引用关联的对象,在将要发生内存溢出异常之前,会被放入回收范围之中以进行第二次回收(如果第二次回收之后依旧没有足够的内存,那么就会抛出OOM异常),也就是说内存不够时,回收SoftReference引用的对象。
- 弱引用: 通过WeakReference类来间接引用目标对象。弱引用表示一个非必需的对象,但要比软引用的强度还要弱。被弱引用关联的对象只能存活到下一次垃圾回收发生之前,当触发垃圾回收时,无论当前内存是否足够,都会回收掉只被弱引用关联的对象(如果这个对象还被强引用所引用,那么就不会被回收)。
- 虚引用: 通过PhantomReference类来间接引用目标对象。虚引用是一种最弱的引用关系,一个对象是否有虚引用的存在,完全不会对其生存时间构成影响,也无法通过虚引用来获得对象实例。虚引用的唯一作用就是能在这个对象被回收时收到一个系统通知(结合ReferenceQueue使用)。基于这点可以通过虚引用来实现对象的析构函数,这比使用finalize()函数是要靠谱多了。
二、用途
- WeekHashMap适用于当缓存来用,基于弱引用的缓存项,会在内存不足时,被GC回收。
- key是弱引用,value一般为强引用,如果发生引用循环,那么会对key回收发生阻碍。这种情况下,只能将value指定为WeekReference引用。

三、分析
1.buckets数组
Entry<K,V>[] table;
private Entry<K,V>[] newTable(int n) {
return (Entry<K,V>[]) new Entry<?,?>[n];
}
2. get函数
// 空值key
private static final Object NULL_KEY