JVM垃圾回收行为的并行与并发

并发和并行是计算机科学中的重要概念。并发是指多个程序在一段时间内看似同时执行,实际上通过CPU时间片切换实现。并行则指多个程序在同一时间点真正同时运行,尤其在多CPU或多核环境下。在垃圾回收中,并行垃圾收集器如ParNew、ParallelScavenge等在用户线程等待时工作,而并发垃圾收集器如CMS、G1允许用户线程与垃圾收集线程交替执行,减少停顿时间。
摘要由CSDN通过智能技术生成

程序的并行和并发

程序的并发(Concurrent)

  • 在操作系统中,是指一个时间段中有几个程序都处于己启动运行到运行完毕之间,且这几个程序都是在同一个处理器_上运行。
  • 并发不是真正意义上的“同时进行”,只是CPU把一个时间段划分成几个时间片段(时间区间),然后在这几个时间区间之间来回切换,由于CPU处理的速度非常快,只要时间间隔处理得当,即可让用户感觉是多个应用程序同时在进行。

程序的并行(Parallel)

  • 当系统有一个以上CPU时,当一个CPU执行一个进程时,另一个CPU可以执行另一个进程,两个进程互不抢占CPU资源,可以同时进行,我们称之为并行(Parallel)。
  • 其实决定并行的因素不是CPU的数量,而是CPU的核心数量,比如一个CPU多个核也可以 并行。
  • 适合科学计算,后台处理等弱交互场景

二者对比

  • 并发,指的是多个事情,在同一时间段内同时发生了。
  • 并行,指的是多个事情,在同一时间点上同时发生了。
  • 并发的多个任务之间是互相抢占资源的。
  • 并行的多个任务之间是不互相抢占资源的。
  • 只有在多CPU或者一个CPU多核的情况中,才会发生并行。否则,看似同时发生的事情,其实都是并发执行的。

垃圾回收的并发与并行

并发和并行,在谈论垃圾收集器的上下文语境中,它们可以解释如下:

  • 并行(Parallel) :指多条垃圾收集线程并行工作,但此时用户线程仍处于等待状态。

    • 如ParNew、 Parallel Scavenge、 Parallel 0ld;
  • 串行(Serial)

    • 相较于并行的概念,单线程执行。
    • 如果内存不够,则程序暂停,启动JVM垃圾回收器进行垃圾回收。回收完,再启动程序的线程。

  • 并发(Concurrent) :指用户线程与垃圾收集线程同时执行(但不一定是并行的,可能会交替执行),垃圾回收线程在执行时不会停顿用户程序的运行。
    • ➢用户程序在继续运行,而垃圾收集程序线程运行于另一个CPU上;
    • ➢如: CMS、G1

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值