GC相关面试题

一、Object的finalize()方法的作用是否与C++的析构函数作用相同

答案是不同的:
析构函数的调用是确定的,当对象不在作用域时就会调用析构函数,而finalize()方法的调用是不确定的;

当垃圾回收机制宣告一个对象死亡时,需要经过两个过程,如果对象经过可达性分析后没有被对象引用就会被第一次标记,并且判断是否执行finalize()方法,如果对象覆盖finalize()方法且未被引用过就会将该对象放置在F-Queue队列中,并在稍后由虚拟机创建的低优先级的线程去执行finalize()方法;

由于该线程优先级低,所以不承诺等待其完成,也就是可能随时会被终止;

finalize()方法的作用是给对象最后一次重生的机会;

二、Java中的强引用,软引用,弱引用,虚引用有什么用

强引用
最普遍的引用:Object obj=new Object();
如果内存不够,直接抛出OutOfMemoryError来终止程序,并不会回收具有强引用的对象;
想要回收强引用有两种方式,一个是讲该对象设置为null来弱化引用,另一个就是等该对象跳出了生命周期,这样就会被回收了;

软引用
对象处在有用但是非必须的状态;
如果内存空间不足,GC就会回收该对象的内存;
可以用来实现高速缓存;
使用方式:

String str=new String("str"); //强引用
        SoftReference<String> stringSoftReference = new SoftReference<>(str); //软引用

弱引用
非必须的对象,比软引用更弱一些;
GC时会被回收,不过被回收的概率也不大,毕竟GC线程的优先级比较低;
适用于引用偶尔被使用且不影响垃圾收集的对象;
使用方式:

        String str=new String("str"); //强引用
        WeakReference<String> stringWeakReference = new WeakReference<>(str); //弱引用

虚引用
不会决定对象的生命周期;
任何时候都可能被垃圾收集器回收;
可以跟踪被垃圾收集器回收的活动,起到一个哨兵的作用;
必须和引用队列ReferenceQueue联合使用
使用方式:

        String str=new String("str"); //强引用
        ReferenceQueue referenceQueue = new ReferenceQueue();
        PhantomReference phantomReference = new PhantomReference(str, referenceQueue);

总结一下:
从强度比较:强引用>软引用>弱引用>虚引用
在这里插入图片描述
从类层次结构来比较:
在这里插入图片描述
最后我们在聊一下什么是引用队列(ReferenceQueue)
无实际的存储结构,存储逻辑依赖于内部节点之间的关系来表达;
存储关联的且被GC的软引用,弱引用,虚引用;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是几个 JVM 垃圾回收相关面试题及其答案: 1. 什么是垃圾回收? 垃圾回收是指在程序运行过程中,自动回收不再使用的内存空间,以提高内存利用率和程序的性能。 2. JVM 的垃圾回收机制是什么? JVM 的垃圾回收机制采用分代收集算法,将内存分为新生代和老年代,分别采用不同的垃圾回收算法来回收内存。 3. 新生代垃圾回收器有哪些? 新生代垃圾回收器主要有 Serial、ParNew、Parallel Scavenge 等。 4. 老年代垃圾回收器有哪些? 老年代垃圾回收器主要有 Serial Old、Parallel Old、CMS、G1 等。 5. 什么是对象的引用计数算法? 引用计数算法是一种简单的垃圾回收算法,它通过记录每个对象被引用的次数,当引用次数为 0 时,即可将该对象回收。 6. 引用计数算法的缺点是什么? 引用计数算法的缺点是无法处理循环引用的情况,如果两个对象之间相互引用,它们的引用计数会一直不为 0,导致无法回收。 7. 什么是标记-清除算法? 标记-清除算法是一种常见的垃圾回收算法,它将垃圾回收分为两个阶段:标记阶段和清除阶段。在标记阶段,标记所有活跃对象,将其打上标记;在清除阶段,清除所有未标记的对象。 8. 标记-清除算法的缺点是什么? 标记-清除算法的缺点是会产生大量的内存碎片,会导致内存利用率降低。 以上是一些常见的 JVM 垃圾回收面试题及其答案,希望能对你有所帮助。在面试过程中,需要根据具体的问题进行回答,同时也需要对垃圾回收机制和算法有清晰的认识,才能更好地回答相关的问题。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值