标签:head 好用 虚引用 guava 清理 ash tps 有关 自己
引用级别:强引用 > 软引用 > 弱引用 > 虚引用
就如最开始说的,设置四种引用类型,是为了更好的控制对象的生命周期,让代码能够一定程度上干涉GC过程,所以引用类型主要就是跟垃圾回收有关了。
对于JVM、GC和内存,可以这样理解,内存好比你的抽屉,这个抽屉有一定大小,并不能无限存放东西。
JVM好比你自己,会时不时来整理抽屉。那些申请的对象好比放在抽屉里的东西,生活中的必需品就好比强引用,而那些可能用到的东西(非必需品)就好比软引用或者弱引用。
当抽屉还很空的时候,放一些非必须品你也不会在意,但是随着买的东西越来越多,抽屉里快放不下的时候,就需要根据重要程度来选择一些东西扔出抽屉,这个过程就好比GC。
JVM在内存够用的时候,不会对软引用的对象进行回收,但是当内存紧张的时候,就会对它们进行清理。
引用类型 | 引用对象被垃圾回收的时间 | 用途 | 是否可以转为强引用 | 对应的类 |
---|---|---|---|---|
强引用 | 从来不会 | 一般用途,保持对象不被回收 | 可以 | 默认 |
软引用 | 发生一次GC后,JVM决定还需要进一步回收更多空间时 | 缓存,保持对象在内存足够时不被回收 | 可以 | SoftReference |
弱引用 | 进行垃圾回收时,如果对象只存在弱引用 | 缓存,仅仅在对象仍被使用时保持其不被回收 | 可以 | WeakReference WeakHashMap |
虚引用 | 进行垃圾回收时 | 跟踪GC过程,在对象被回收前进行一些清理工作 | 不可以 | PhantomReference |
emmmm….总觉得少了点什么,有没有想过,为什么没有StrongReference类?
嗯,讲道理,软引用,弱引用,虚引用都有其对应的类,为什么强引用却没有?试想一下,如果有StrongReference类,那么在自定义缓存中进行引用类型判断时将会比较方便,事实上,在guava的LocalCache中,确实构造了一个StrongValueReference的类,用来包裹一个强引用。
所以当你想要自己造缓存的轮子时,可以先看看人家的轮子好不好用。
至此,这一系列就算告一段落了,为了写这一系列文章,花了不少心思,离底层实现越来越近的感觉就像山洞探险,这个探索过程的曲径通幽,柳暗花明处其实就是最好的奖励。
对于学习,就像是打通经脉的过程,从一个一个零散的点,到慢慢将它们贯通成线,点与点的联结会让人产生极大的快感,最终如果能将这些点编织成网,便像打通奇经八脉那样,知识不过是手到擒来了。
(这个B装的不错,还多了一些细节在里面,哈哈哈哈,溜了溜了)
标签:head 好用 虚引用 guava 清理 ash tps 有关 自己
原文地址:https://www.cnblogs.com/mfrank/p/10472606.html