常见面试题
常见面试题
Object的finalize()方法的作用是否与C++的析构函数作用相同
finalize()方法
垃圾回收器准备释放内存的时候,会先调用finalize()。
- 与C++的析构函数不同,析构函数调用确定,而它的是不确定的
- 当对象变成(GC Roots)不可达时,GC会判断该对象是否覆盖了finalize方法,若未覆盖,则直接将其回收。否则,若对象未执行过finalize方法,将其放入F-Queue队列,由一低优先级线程执行该队列中对象的finalize方法。执行finalize方法完毕后,GC会再次判断该对象是否可达,若不可达,则进行回收,否则,对象“复活”。
- 方法执行随时可能被终止
- 给与对象最后一次重生的机会
对象不一定会被回收。
垃圾回收不是析构函数。
垃圾回收只与内存有关。
垃圾回收和finalize()都是靠不住的,只要JVM还没有快到耗尽内存的地步,它是不会浪费时间进行垃圾回收的。
Java中的强引用,软引用,弱引用,虚引用有什么用
强引用
- 最普遍的引用:Object obj = new Object();
- 抛出OutOfMemoryError终止程序也不会回收具有强引用的对象
- 通过将对象设置为null来弱化引用,使其被回收
软引用
- 对象处在有用但非必须的状态
- 只有当内存空间不足时,GC会回收该引用的对象的内存
- 可以用来实现高速缓存
弱引用
- 非必须的对象,比软引用更弱
- GC时会被回收无论内存是否足够
- 被回收的概率也不大,因为GC线程优先级比较低
- 适用于引用偶尔被使用且不影响垃圾收集的对象
虚引用
- 不会决定对象的生命周期
- 如果一个对象仅持有虚引用,那么和没有任何引用一样,任何时候都可能被垃圾回收器回收
- 主要用来跟踪对象被垃圾回收器回收的活动,起哨兵作用
- 必须和引用队列ReferenceQueue联合使用
引用队列(ReferenceQueue)
- 无实际存储结构,存储逻辑依赖于内部节点之间的关系来表达
- 存储关联的且被GC的软引用,弱引用以及虚引用
本博客所有文章除特别声明外,均采用 CC BY-NC-SA 4.0 许可协议。转载请注明来自 Alfred的小站!