源码分析三、Map(5)-WeekHashMap

一、概述

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

二、用途

  1. WeekHashMap适用于当缓存来用,基于弱引用的缓存项,会在内存不足时,被GC回收。
  2. 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 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值