面经-虚拟机-finalize
当重写了finalize方法的对象,在构造方法调用时,jvm会将其包装成一个finalizer对象,并加入unfinalized队列中(双向链表)。当进行垃圾回收时,将这些对象对应的finalizer对象加入一个空的队列ReferenceQueue(单向链表)。
真正的回收时机:即时对象无人引用,由于finalizer还在引用它,所以无法被回收。finalizerThread线程从ReferenceQueue中逐一取出每个finalizer对象,把他们从链表中断开,这样没人引用它,下次gc被回收。
## 为什么finalize方法非常不好,非常影响性能?
1.finalizeThred是守护线程,代码可能还没执行完,线程就结束了,导致资源未正确释放。
2.finalize执行中不会报异常,判断不了释放资源时的错误。
影响性能:
1.第一次被gc时不能及时释放内存。
2.gc本就是因内存不足引起,finalize调用又很慢,对象不及时释放会进入老年代,老年代内存不足会引起full gc,full gc后如果内存还跟不上创建新对象速度,就会导致内存溢出。
真正的回收时机:即时对象无人引用,由于finalizer还在引用它,所以无法被回收。finalizerThread线程从ReferenceQueue中逐一取出每个finalizer对象,把他们从链表中断开,这样没人引用它,下次gc被回收。
## 为什么finalize方法非常不好,非常影响性能?
1.finalizeThred是守护线程,代码可能还没执行完,线程就结束了,导致资源未正确释放。
2.finalize执行中不会报异常,判断不了释放资源时的错误。
影响性能:
1.第一次被gc时不能及时释放内存。
2.gc本就是因内存不足引起,finalize调用又很慢,对象不及时释放会进入老年代,老年代内存不足会引起full gc,full gc后如果内存还跟不上创建新对象速度,就会导致内存溢出。