当重写了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后如果内存还跟不上创建新对象速度,就会导致内存溢出。
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/128059.html