垃圾收集器

一、GC垃圾回收算法和垃圾收集器的关系?

答:GC算法时内存回收的方法论,垃圾收集器就是算法落地实现。

二、4种主要垃圾收集器?

①串行回收Serial----->为单线程环境设计且只使用一个线程进行垃圾回收,会暂停所有的用户线程。所以不适合服务器环境。

②并行回收Parallel----->多个垃圾收集线程并行工作,此时用户线程也时暂停的,适用于科学计算/大数据处理首台处理等弱交互(就是跟前台的交互没那么强,允许你稍微停一下)场景

③并发标记清除CMS(但是有时候,我们生产服务器,程序时不能停的):用户线程和垃圾收集线程同时执行(不一定是并行,可能交替执行),不需要停顿用户线程,互联网公司多用它,适用对响应时间有要求的场景。(强交互的场景)

(是Java8的默认垃圾回收器)

Java8以前,主要是以上3种

④G1(Java8开始使用)Java9开始默认G1垃圾回收器,Java11是ZGC:

G1垃圾回收器将堆内存割成不同的域然后并发的对其进行垃圾回收

三、怎么查看服务器默认的垃圾收集器是哪个?

四、默认的垃圾收集器有哪些?

六种

六、新生代的垃圾收集器有

①串行GC(Serial):Serial垃圾收集器是JVM运行在Client模式下默认的新生代垃圾收集器。 对应JVM参数是:-XX:+UseSerialGC。开启后Old区就跟跟随着Young用Serial Old收集器(即新生代用了串行,老年代也会使用串行回收收集器,不同的是新生代使用复制算法,老年代使用标记-整理算法)

②并行GC(ParNew):ParNew收集器是很多Java虚拟机运行在Server模式下新生代的默认垃圾收集器。对应JVM参数:-XX:+UserParNewGC。ParNew说明只是新生代用并行,老年代还是用串行

新生代使用多线程GC,老年代使用单线程GC,同样,新生代使用复制算法,老年代使用标记-整理算法

ParNew收集器其实就是Serial收集器新生代的并行多线程版本

③并行回收GC

新生代和老年区的垃圾回收器搭配:

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值