下面来分析一下与Reference有关的sun.misc.Cleaner和java.lang.ref.Finalizer。
 
先来看Finalizer,Finalizer扩展了Reference,故其本质也是一个Reference,与SoftReference、WeakReference、PhantomReference不同的是gc遇到FinalReference后,并不会回收其referent,而只是入队,所入队列就是下图的queue,FinalizerThread会处理该队列。
 
java基础-Reference三

 

FinalizerThread的主要逻辑:
 java基础-Reference三
 
runFinalizer方法:
java基础-Reference三

 

这里还有一个隐藏问题,就是Finalizer对象由谁来维护?SoftReference是由我们自己来维护的,比如充当缓存(map)中的value,Finalizer是由其自身维护的,在Finalizer中有一个unfinalized静态字段,该字段用来存放Finalizer实例,这样就可以保证Finalizer在执行referent的finalize方法前不会被gc回收。
 java基础-Reference三

 

再来看一下Cleaner,cleaner扩展了PhantomReference,经过之前的讨论我们知道,PhantomReference只适合做对象回收的跟踪,而不能做对象的存取,Cleaner所需要的就是跟踪到对象(比如ByteBuffer)被gc回收后,做出相应逻辑处理。
 java基础-Reference三
 
之前提到过,clean方法会在HandlerThread中被调用,并且Cleaner不会入队。
java基础-Reference三

 

相关文章:

  • 2021-09-07
  • 2021-11-29
  • 2022-12-23
  • 2021-07-27
  • 2021-06-24
  • 2022-12-23
猜你喜欢
  • 2022-12-23
  • 2022-12-23
  • 2021-05-09
  • 2021-09-11
  • 2022-01-16
相关资源
相似解决方案