首页 > 编程语言 >Java 8默认垃圾回收器

Java 8默认垃圾回收器

时间:2024-09-16 11:22:55浏览次数:3  
标签:Java 回收 XX 默认 垃圾 JVM Parallel

Java 8作为Java语言的重要里程碑,不仅引入了Lambda表达式、Stream API等新特性,还在垃圾回收(Garbage Collection, GC)方面继续沿用了Java 7的策略,但同时也提供了新的垃圾回收器选项。在本文中,我们将深入探讨Java 8的默认垃圾回收器以及如何查看和理解相关的JVM参数。


Java 8默认垃圾回收器

Java 8的默认垃圾回收器是Parallel Scavenge(用于新生代)和Parallel Old(用于老年代)。这种组合提供了高效的内存回收性能,尤其适合于多核处理器环境。


Parallel Scavenge

Parallel Scavenge是一个年轻代的垃圾回收器,它使用并行的复制算法来回收内存。这个收集器的主要目标是提供可预测的吞吐量,即应用程序运行时间与垃圾回收时间的比率。


Parallel Old

Parallel Old是Parallel Scavenge的老年代对应收集器,使用多线程的标记-整理算法进行内存回收。这个收集器可以与Parallel Scavenge配合使用,以实现整个堆的高效垃圾回收。


如何查看Java 8的默认垃圾回收器

要查看Java 8的默认垃圾回收器,你可以使用以下两种方法:


1. 使用命令行参数

打开命令行工具,输入以下命令:


java -XX:+PrintCommandLineFlags -version

1

这个命令会输出JVM启动时使用的命令行参数,包括垃圾回收器的配置。例如:


-XX:InitialHeapSize=534729792 -XX:MaxHeapSize=8555676672 -XX:+PrintCommandLineFlags -XX:+UseCompressedClassPointers -XX:+UseCompressedOops -XX:-UseLargePagesIndividualAllocation -XX:+UseParallelGC

1

在这个输出中,-XX:+UseParallelGC参数表明JVM使用了Parallel Scavenge和Parallel Old作为默认的垃圾回收器。


2. 使用Java管理扩展(JMX)API

你可以编写一个简单的Java程序来查询当前JVM使用的垃圾回收器:


import java.lang.management.GarbageCollectorMXBean;

import java.lang.management.ManagementFactory;

import java.util.List;


public class GcCollectorPrinter {

   public static void main(String[] args) {

       List<GarbageCollectorMXBean> beans = ManagementFactory.getGarbageCollectorMXBeans();

       for (GarbageCollectorMXBean bean : beans) {

           System.out.println(bean.getName());

       }

   }

}

 

运行这个程序,它会打印出当前JVM使用的垃圾回收器的名称列表。

基准方法

  • 使用不同的VM参数运行相同的代码6次( -XX:+UseSerialGC , -XX:+UseParallelGC , -XX:+UseConcMarkSweepGC , -XX:ParallelCMSThreads=2 , -XX:ParallelCMSThreads=4 , -XX:+UseG1GC ) 。
  • 每次运行大约需要55分钟。
  • 其他VM参数: -Xmx2048M -serverOpenJDK版本: 1.8.0_51 (当前最新版本)
    软体: Linux version 4.0.4-301.fc22.x86_64 硬件: Intel® Core™ i7-4790 CPU @ 3.60GHz
  • 每次运行都能使用OptaPlanner解决13个计划问题。 每个计划问题要运行5分钟。 它以30秒的JVM预热开始,该预热将被丢弃。
  • 解决计划问题不涉及任何IO (启动期间要加载输入的时间只有几毫秒)。 一个CPU完全饱和。 它会不断创建许多短命的对象,然后GC会收集它们。
  • 基准衡量每毫秒可以计算的分数数量。 越高越好。 为拟议的规划解决方案计算分数并非易事:涉及许多计算,包括检查每个实体与每个其他实体之间的冲突。

结论

Java 8通过使用Parallel Scavenge和Parallel Old作为默认垃圾回收器,为开发者提供了一个高效且适合多核处理器的垃圾回收解决方案。通过命令行参数和JMX API,我们可以轻松地查看和验证JVM的垃圾回收器配置,从而更好地理解和优化Java应用程序的性能。


标签:Java,回收,XX,默认,垃圾,JVM,Parallel
From: https://blog.51cto.com/u_16271212/12030542

相关文章

  • Java计算机毕业设计易得物交换平台(开题报告+源码+论文)
    本系统(程序+源码)带文档lw万字以上 文末可获取一份本项目的java源码和数据库参考。系统程序文件列表开题报告内容研究背景随着互联网技术的飞速发展,人们的消费观念和交易方式正经历着深刻变革。在资源日益紧张、环保意识增强的今天,物物交换作为一种绿色、低碳的交易模式,逐......
  • Java计算机毕业设计新疆在线旅游网站的设计与实现(开题报告+源码+论文)
    本系统(程序+源码)带文档lw万字以上 文末可获取一份本项目的java源码和数据库参考。系统程序文件列表开题报告内容研究背景随着互联网的飞速发展,旅游业正经历着前所未有的变革。新疆,作为中国西北边陲的一颗璀璨明珠,以其壮丽的自然风光、丰富的民族文化、独特的地理位置吸引......
  • 高级Java程序员必备的技术点:你准备好了吗?
    在Java编程的世界里,成为一名高级程序员不仅需要深厚的基础知识,还需要掌握一系列高级技术和最佳实践。这些技术点是通向技术专家之路的敲门砖,也是应对复杂项目挑战的利器。本文将探讨高级Java程序员必备的技术点,帮助你自我提升,迈向更高的职业巅峰。1.深入理解Java虚拟机(JVM)掌握JVM......
  • Java+Vue开发的固定资产管理系统(项目源代码分享)
      前言:资产设备管理系统旨在实现对企业资产和设备的全面管理,通过信息化手段提升管理效率,确保资产和设备的有效利用和安全性。以下是该系统的主要功能模块及其详细描述:一、个人中心用户登录与权限管理:实现用户身份验证和权限分配,确保系统数据的安全性。个人信息管理:允许用......
  • JavaScript-apply、bind、call
    call、apply、bind作用是改变函数执行时的上下文,简而言之就是改变函数运行时的this指向区别 applyapply接受两个参数,第一个参数是this的指向,第二个参数是函数接受的参数,以数组的形式传改变this指向后原函数会立即执行,且此方法只是临时改变this指向一次当第一个参数......
  • idea运行java项目main方法报build failure
    在使用IntelliJIDEA运行Java项目的 main 方法时,如果遇到"BuildFailure"错误,通常意味着在构建项目时出现了问题。以下是一些常见的解决方法:1.检查项目结构确保你的项目结构正确,特别是 src 目录和 main 方法所在的类文件路径是否正确。2.检查编译输出路径确保Intell......
  • 【开源免费】基于SpringBoot+Vue.JS企业客户管理系统(JAVA毕业设计)
    本文项目编号T036,文末自助获取源码\color{red}{T036,文末自助获取源码}......
  • 【开源免费】基于SpringBoot+Vue.JS学生宿舍管理系统(JAVA毕业设计)
    本文项目编号T035,文末自助获取源码\color{red}{T035,文末自助获取源码}......
  • 高级Java程序员必备的技术点:你准备好了吗?
    在Java编程的世界里,成为一名高级程序员不仅需要深厚的基础知识,还需要掌握一系列高级技术和最佳实践。这些技术点是通向技术专家之路的敲门砖,也是应对复杂项目挑战的利器。本文将探讨高级Java程序员必备的技术点,帮助你自我提升,迈向更高的职业巅峰。深入理解Java虚拟机(JVM)掌握JV......
  • JavaScript 手写new操作符
    new关键字的工作步骤创建一个新的对象obj将对象与构建函数通过原型链连接起来将构建函数中的this绑定到新建的对象obj上根据构建函数返回类型作判断,如果是原始值则被忽略,如果是返回对象,需要正常处理constrecodeNew=function(Func,...args){//获取函数对象......