选项与默认值
默认值与限制
描述
-XX:+AggressiveOpts |
JDK 5 update 6后引入,但需要手动启用。
JDK6默认启用。 |
启用JVM开发团队最新的调优成果。例如编译优化,偏向锁,并行年老代收集等。 |
-XX:CompileThreshold=10000 |
1000 |
通过JIT编译器,将方法编译成机器码的触发阀值,可以理解为调用方法的次数,例如调1000次,将方法编译为机器码。 |
-XX:LargePageSizeInBytes=4m |
默认4m
amd64位:2m |
设置堆内存的内存页大小。 |
-XX:MaxHeapFreeRatio=70 |
70 |
GC后,如果发现空闲堆内存占到整个预估上限值的70%,则收缩预估上限值。
什么是预估上限值?
JVM在启动时,会申请最大值(-Xmx指定的数值)的地址空间,但其中绝大部分空间不会被立即分配(virtual)。
它们会一直保留着,直到运行过程中,JVM发现实际占用接近已分配上限值时,才从virtual里再分配掉一部分内存。
这里提到的已分配上限值,也可以叫做预估上限值。
引入预估上限值的好处是,可以有效地控制堆的大小。堆越小,GC效率越高嘛。
注意:预估上限值的大小一定小于或等于最大值。 |
-XX:MaxNewSize=size |
1.3.1 Sparc: 32m
1.3.1 x86: 2.5m |
新生代占整个堆内存的最大值。 |
-XX:MaxPermSize=64m |
5.0以后: 64 bit VMs会增大预设值的30%
1.4 amd64: 96m
1.3.1 -client: 32m
其他默认 64m |
Perm(俗称方法区)占整个堆内存的最大值。 |
-XX:MinHeapFreeRatio=40 |
40 |
GC后,如果发现空闲堆内存占到整个预估上限值的40%,则增大上限值。
(什么是预估上限值?见 -XX:MaxHeapFreeRatio 处的描述)
关联选项:
-XX:MaxHeapFreeRatio=70 |
-XX:NewRatio=2 |
Sparc -client: 8
x86 -server: 8
x86 -client: 12
-client: 4 (1.3)
8 (1.3.1+)
x86: 12
其他默认 2 |
新生代和年老代的堆内存占用比例。
例如2例如2表示新生代占年老代的1/2,占整个堆内存的1/3。 |
-XX:NewSize=2.125m |
5.0以后: 64 bit Vms 会增大预设值的30%
x86: 1m
x86, 5.0以后: 640k
其他默认 2.125m |
新生代预估上限的默认值。(什么是预估上限值?见 -XX:MaxHeapFreeRatio 处的描述) |
-XX:ReservedCodeCacheSize=32m |
Solaris 64-bit, amd64, -server x86: 48m
1.5.0_06之前, Solaris 64-bit amd64: 1024m
其他默认 32m |
设置代码缓存的最大值,编译时用。 |
-XX:SurvivorRatio=8 |
Solaris amd64: 6
Sparc in 1.3.1: 25
Solaris platforms 5.0以前: 32
其他默认 8 |
Eden与Survivor的占用比例。例如8表示,一个survivor区占用 1/8 的Eden内存,即1/10的新生代内存,为什么不是1/9?
因为我们的新生代有2个survivor,即S1和S22。所以survivor总共是占用新生代内存的 2/10,Eden与新生代的占比则为 8/10。 |
-XX:TargetSurvivorRatio=50 |
50 |
实际使用的survivor空间大小占比。默认是50%,最高90%。 |
-XX:ThreadStackSize=512 |
Sparc: 512
Solaris x86: 320 (5.0以前 256)
Sparc 64 bit: 1024
Linux amd64: 1024 (5.0 以前 0)
其他默认 512. |
线程堆栈大小 |
-XX:+UseBiasedLocking |
JDK 5 update 6后引入,但需要手动启用。
JDK6默认启用。 |
启用偏向锁。 |
-XX:+UseFastAccessorMethods |
默认启用 |
优化原始类型的getter方法性能。 |
-XX:+UseLargePages |
JDK 5 update 5后引入,但需要手动启用。
JDK6默认启用。 |
启用大内存分页。
关联选项
-XX:LargePageSizeInBytes=4m |
-XX:+StringCache |
默认启用 |
启用字符串缓存。 |
相关推荐
Java 6 JVM 参数选项是Java虚拟机的配置设置,用于优化JVM的行为和性能。这些参数通常以-XX:开头,允许开发者调整JVM内部的工作机制,以适应特定的应用场景和性能需求。以下是一些关键的JVM选项及其详细解释: 1. -...
### Java 6 JVM 参数选项详解 #### 概述 Java虚拟机(JVM)作为Java程序执行的基础环境,其配置参数对于确保应用高效稳定运行至关重要。特别是在Java、J2EE等大型应用中,通过合理设置JVM参数可以极大提升系统的...
### JVM参数配置详解 #### 一、理解JVM参数配置的重要性 Java Virtual Machine (JVM) 是运行Java程序的核心环境,其性能...希望本文能为读者提供一个深入理解JVM参数配置的起点,引导大家探索更高级的性能优化技术。
《实战JAVA虚拟机—JVM故障诊断与性能优化》是一本深入探讨Java虚拟机(JVM)技术的书籍,旨在帮助开发者和系统管理员诊断并优化JVM相关的性能问题。本书内容丰富,涵盖了大量的实践案例,使得即便是初学者也能理解...
JVM参数设置是优化Java应用性能的关键环节,它可以帮助我们控制JVM的行为,如内存分配、垃圾回收策略、线程调度等。下面将详细介绍一些重要的JVM参数及其作用。 1. 内存设置: - `-Xms` 和 `-Xmx`:这两个参数用于...
在Java 6中,开发者可以通过指定一系列的参数来控制JVM的行为,以优化程序性能、调整内存分配或者进行调试。本文将深入探讨Java 6 JVM的参数选项,并提供中文解析。 1. **JVM启动参数类型** - **预设参数 (-X):**...
Java虚拟机(JVM)是Java程序运行的基础,它的配置参数和垃圾收集(GC)机制对于优化应用程序性能至关重要。本文将深入探讨JVM参数及其与Java垃圾收集相关的知识。 一、JVM参数详解 JVM参数可以分为三类:启动参数...
Java虚拟机(JVM)参数选项对于优化Java应用程序的性能、内存管理和稳定性至关重要。Java 6版本的JVM提供了大量的可调整参数,这些参数通常被称为非稳态选项,因为它们可以改变JVM的行为而不影响其运行时的稳定性。...
为了更好地理解和分析JVM行为,开发者通常会借助各种工具,如VisualVM、JProfiler和JConsole等。这些工具可以实时监控JVM的内存状态、CPU使用率、线程情况,帮助定位性能瓶颈。 总的来说,深入理解Java虚拟机对于...
在《实战Java虚拟机——JVM故障诊断与性能优化》一书中,作者深入探讨了如何对JVM进行故障排查和性能调优,通过源码分析来帮助读者理解其内部工作原理。下面我们将根据书中的主题,详细阐述相关的知识点。 1. **JVM...
《实战JAVA虚拟机 JVM故障诊断与性能优化》是一本深度探讨Java虚拟机(JVM)的书籍,旨在帮助开发者解决在实际工作中遇到的JVM相关问题,提升系统的性能。这本书提供了丰富的源码实例,让读者能够深入理解JVM的工作...
JVM的参数配置是优化Java应用程序性能的关键环节,对于开发者来说,理解和掌握JVM参数的设置至关重要。 在Java中,JVM参数分为两种类型:标准(Standard)和非标准(Non-Standard)。标准参数以"-X"开头,这些参数...
Java虚拟机(JVM)参数调优和相关工具的使用对于优化Java应用程序的性能至关重要。JVM负责管理和分配内存,其中垃圾收集(GC)是其核心功能,它自动管理内存,确保活动对象保留在内存中,同时释放不再使用的对象以...
"java虚拟机(jvm)介绍以及相关参数设置与调优" Java虚拟机(JVM)是Java平台的核心组件之一,它提供了一个运行Java字节码的环境,并且负责管理Java程序的内存分配和垃圾回收。在本文中,我们将深入探讨Java虚拟机...
性能调优不仅需要了解JVM参数,还需要关注参数的具体含义和应用。例如,“-Xms”和“-Xmx”分别用于设置JVM的初始堆内存和最大堆内存,“-Xss”用于设置线程堆栈大小,“-Xmn”用于设置年轻代内存大小。而“-XX”...
Java虚拟机(JVM)参数对于优化Java应用程序的性能至关重要。这些参数用于调整JVM的内存分配、垃圾收集行为以及各种其他配置选项。以下是一些关键的JVM参数及其作用: 1. **Xms** 和 **Xmx**: 这两个参数用于设置...