深圳西丽网站建设公司,如何给自己公司做网站,如何建立小企业网站,室内设计平面方案讲解文章目录 1. 查看默认GC2. Serial GC : 串行回收3. ParNew GC#xff1a;并行回收4. Parallel GC#xff1a;吞吐量优先 1. 查看默认GC
-XX:PrintCommandLineFlags#xff1a;查看命令行相关参数#xff08;包含使用的垃圾收集器#xff09;使用命令行指令#xff1a;ji… 文章目录 1. 查看默认GC2. Serial GC : 串行回收3. ParNew GC并行回收4. Parallel GC吞吐量优先 1. 查看默认GC
-XX:PrintCommandLineFlags查看命令行相关参数包含使用的垃圾收集器使用命令行指令jinfo –flag 相关垃圾回收器参数 进程ID jinfo -flag UseParallelGC 10098 2. Serial GC : 串行回收
概述
Serial收集器是最基本、历史最悠久的垃圾收集器了。JDK1.3之前回收新生代唯一的选择。Serial收集器作为HotSpot中Client模式下的默认新生代垃圾收集器。Serial 收集器 采用 复制算法、串行回收和”Stop-the-World”机制 的方式执行内存回收。除了年轻代之外Serial收集器还提供用于执行老年代垃圾收集的Serial Old收集器。Serial Old 收集器同样也采用了串行回收和”Stop the World”机制只不过内存回收算法使用的是标记-压缩算法。 Serial Old 是运行在 Client 模式下默认的老年代的垃圾回收器Serial Old 在 Server 模式下主要有两个用途① 与新生代的Parallel Scavenge配合使用 ② 作为老年代CMS收集器的后备垃圾收集方案 这个收集器是一个单线程的收集器但它的“单线程”的意义并不仅仅说明它只会使用一个 CPU 或一条收集线程去完成垃圾收集工作更重要的是在它进行垃圾收集时必须暂停其他所有的工作线程直到它收集结束Stop The World。 优势简单而高效与其他收集器的单线程比对于限定单个 CPU 的环境来说Serial收集器由于没有线程交互的开销专心做垃圾收集自然可以获得最高的单线程收集效率。 运行在Client模式下的虚拟机是个不错的选择。
在用户的桌面应用场景中可用内存一般不大几十MB至一两百MB可以在较短时间内完成垃圾收集几十ms至一百多ms,只要不频繁发生使用串行回收器是可以接受的。
参数 在HotSpot虚拟机中使用 -XX:UseSerialGC 参数可以指定年轻代和老年代都使用串行收集器。 等价于 新生代用Serial GC且老年代用Serial Old GC
小结
这种垃圾收集器大家了解现在已经不用串行的了。而且在限定单核cpu才可以用。现在都不是单核的了。 对于交互较强的应用而言这种垃圾收集器是不能接受的。一般在Java web应用程序中是不会采用串行垃圾收集器的。 3. ParNew GC并行回收
概述 如果说Serial GC是年轻代中的单线程垃圾收集器那么ParNew收集器则是Serial收集器的多线程版本。 Par是Parallel的缩写New只能处理的是新生代 ParNew 收集器除了采用并行回收的方式执行内存回收外两款垃圾收集器之间几乎没有任何区别。ParNew收集器在年轻代中同样也是采用复制算法、Stop-the-World机制。 ParNew 是很多JVM运行在Server模式下新生代的默认垃圾收集器。 对于新生代回收次数频繁使用并行方式高效。对于老年代回收次数少使用串行方式节省资源。CPU并行需要切换线程串行可以省去切换线程的资源
参数 在程序中开发人员可以通过选项 -XX:UseParNewGC 手动指定使用ParNew收集器执行内存回收任务。它表示年轻代使用并行收集器不影响老年代。
-XX:ParallelGCThreads 限制线程数量默认开启和 CPU 数据相同的线程数。 4. Parallel GC吞吐量优先
概述 HotSpot的年轻代中除了拥有ParNew收集器是基于并行回收的以外Parallel Scavenge收集器同样也采用了复制算法、并行回收和”Stop the World”机制。 那么Parallel收集器的出现是否多此一举 和ParNew收集器不同Parallel Scavenge收集器的目标则是达到一个可控制的吞吐量Throughput它也被称为吞吐量优先的垃圾收集器。自适应调节策略也是Parallel Scavenge与ParNew一个重要区别。 高吞吐量则可以高效率地利用 CPU 时间尽快完成程序的运算任务主要适合在后台运算而不需要太多交互的任务。因此常见在服务器环境中使用。例如那些执行批量处理、订单处理、工资支付、科学计算的应用程序。 Parallel 收集器在JDK1.6时提供了用于执行老年代垃圾收集的Parallel Old收集器用来代替老年代的Serial Old收集器。 Parallel Old 收集器采用了标记-压缩算法但同样也是基于并行回收和”Stop-the-World”机制。 在程序吞吐量优先的应用场景中 Parallel 收集器和Parallel Old收集器的组合在Server模式下的内存回收性能很不错。在Java8中默认是此垃圾收集器。