`
topzhujia
  • 浏览: 56007 次
  • 性别: Icon_minigender_1
  • 来自: 重庆
社区版块
存档分类
最新评论

Java HOTSPOT VM参数大全

    博客分类:
  • JAVA
阅读更多

SUN的JDK版本从1.3.1开始使用HotSpot虚拟机技术。

  HotSpot是较新的Java虚拟机技术,用来代替JIT(Just in Time)技术,可以大大提高Java运行的性能。

  Java原先是把源代码编译为字节码在虚拟机执行,这样执行速度较慢。而该技术将常用的部分代码编译为本地(原生,native)代码,这样显著提高了性能。用于服务器版和标准版的HotSpot有所不同。

  其他的Java虚拟机也有类似的技术。

  HotSpot JVM 参数可以分为标准参数(standard options)和非标准参数(non-standard options)。

  标准参数相对稳定,在JDK未来的版本里不会有太大的改动。

  非标准参数则有因升级JDK而改变的可能。

  标准参数

  -client

  使用Java HotSpot 客户端版VM。

  -server

  使用Java HotSpot 服务器版VM。如果是64位的JDK,默认只有server版,所以以上两个参数对64位版本JDK无效。

  -agentlib: libname [=options]

  加载本地代理函数库, e.g.

  -agentlib:jdwp=help

  -agentpath :pathname [=options]

  使用给定的路径加载本地代理库。

  -classpath classpath

  -cp classpath

  不用说了。

  -Dproperty =value

  设置一个系统属性。

  -d32

  -d64

  要求程序在32位或64位下跑,未来这个参数可能有变。

  -enableassertions [:"..." | : ]

  -ea [:"..." | : ]

  开启断言。

  -disableassertions [:"..." | : ]

  -da [:"..." | : ]

  关闭断言。

  -enablesystemassertions

  - esa

  启动所有系统类的断言。

  -disablesystemassertions

  -dsa

  关闭所有系统类的断言。

  -jar

  这个也没什么说的。

  -javaagent :jarpath [=options]

  加载Java 程序语言代理

  -verbose:class

  输出每个加载的类详细信息。

  -verbose:gc

  输出GC的详细信息。

  -verbose:jni

  输出本地方法接口的调用信息。

  -version

  -help

  -?

  不用说了。

  -X

  显示可用的非标准参数

 非标准参数

  -Xint

  以解释模式运行。JVM不会使用HotSpot的新特性,不会将部分常用代码编译为本地代码,所有代码都以字节码的方式解释运行。你可以理解为使用JDK1.3.1以前的JIT方式运行程序。

  -Xbatch

  不使用后台编译。

  -Xbootclasspath:bootclasspath

  使用bootstrap classloader 加载指定路径的class或jar,这是种完全覆盖默认系统类加载的方案,慎用。

  -Xbootclasspath/a:bootclasspath

  将指定的classpath追加到默认的bootclasspath的后面加载

  -Xbootclasspath/p:bootclasspath

  将指定的classpath追加到默认的bootclasspath的前面加载

  -Xcheck:jni

  在调用JNI函数时做额外的检查。这个参数会降低JVM的执行性能。

  -Xfuture

  执行严格的class文件格式检查,不加这个参数,默认使用JDK1.1.* 版本的class格式检查方法。

  -Xnoclassgc

  禁用class垃圾收集。

  -Xincgc

  开启增量垃圾收集机制。默认为关闭。增量垃圾收集能减少因垃圾收集而引起的程序中断,它会在程序运行期间不定期地以并发的方式运行,在运行期间不会引起中断但是会减少分配给程序的cpu资源。

  -Xloggc:file

  GC详情日志。效果如-verbose:gc ,不过这个可以输出到一个文件。除了-verbose:gc包含的信息,还有显示发生的时间。 文件可以是远程的,但是考虑到网络延迟会引起JVM中断,一般建议使用本地文件,

  -Xms

  分配的堆空间初始值:

  -Xms6291456

  -Xms6144k

  -Xms6m

  -Xmx

  分配的堆空间最大值:

  -Xmx83886080

  -Xmx81920k

  -Xmx80m

  -Xprof

  在运行程序时给出分析数据。适用于开发环境,不适用于生产环境。

  -Xrs

  减少JVM的操作系统信号的使用量。

  -Xss

  线程栈内存

  非标准-XX参数

  有三种-XX参数的形式:

  Boolean 型的参数 开启如 -XX:+ 关闭如 -XX:-.

  Numeric 型参数 -XX:=. 数字可以包括单位 'm' 或 'M' 代表MB, 'k' or 'K' 代表KB, 'g' or 'G' 代表 GB ,没有单位意味着bytes。

  String 参数 -XX:=

  以下是-XX参数列表,本来想都翻译过来,但是发现一些技术术语如果硬是翻译可能会导致词不达意,因此大部分描述都保持原文。

 

 

 

 

 






分享到:
评论

相关推荐

    借HSDB来探索HotSpot VM的运行时数据.gist1

    HotSpot VM是Oracle JDK中默认的JVM实现,它提供了一种称为HSDB(HotSpot Debugger Bridge)的工具,用于在运行时查看和分析JVM内部的数据。本篇将通过HSDB的使用案例来探讨HotSpot VM的运行时数据。 首先,我们...

    【译】Java 14 Hotspot 虚拟机垃圾回收调优指南(csdn)————程序.pdf

    Java HotSpot VM 提供了两种主要的优化目标:最大暂停时间和应用吞吐量。最大暂停时间目标通过 `-XX:MaxGCPauseMillis` 参数设定,目标是限制垃圾收集暂停的最长时间,以保证应用程序的响应性。吞吐量目标则关注整个...

    HotSpot Runtime概述

    HotSpot运行时系统是Java虚拟机(JVM)的一个实现,专注于提供高性能的Java应用程序执行环境。本节将深入探讨其关键子系统和概念。 首先,我们关注的是**命令行参数处理**。Java HotSpot虚拟机接受多种命令行选项和...

    jvm 参数及gc详解

    Java虚拟机(JVM)是Java...阅读“java hotspot vm options.pdf”、“java se 6 hotspot[tm] virtual machine garbage collection tuning.pdf”和“java工具选项文档.pdf”等资料,将有助于深入学习和实践这些知识。

    jvm技术精华-架构师必备

    ### JVM技术精华——架构师必备知识点...通过深入理解HotSpot VM的历史背景和发展过程,以及Java内存结构的基本概念,架构师们能够更好地掌握Java应用程序的性能调优技巧,这对于提高软件系统的稳定性和性能至关重要。

    hotspot-virtual-machine-garbage-collection-tuning-guide.pdf

    《Java平台标准版HotSpot虚拟机垃圾收集调优指南》是针对Java HotSpot虚拟机(Java HotSpot VM)内建的垃圾收集算法的一份详细指南,旨在帮助开发者和系统管理员选择最适合他们应用需求的垃圾收集策略。这份文档适用...

    JAVA性能优化.docJAVA性能优化.doc

    - **参数调整**:HotSpot VM的性能可以通过设置启动参数来优化,例如使用`-server`选项选择Server VM。内存参数配置也至关重要,包括堆大小(`-Xms`和`-Xmx`)、新生代大小(`-NewSize`和`-MaxNewSize`)、年老代...

    Hotspot源码

    Hotspot源码是Java开发中的重要参考资料,它揭示了Java虚拟机(JVM)的工作原理。Oracle JDK中的Hotspot JVM是Java程序运行的核心,负责字节码解释、编译优化以及垃圾回收等关键任务。Hotspot源码的分析有助于开发者...

    [inside hotspot] java方法调用的StubCode1

    在 HotSpot 的源代码中,`JavaCalls` 类位于 `hotspot/src/share/vm/runtime/javaCalls.hpp` 文件内。该类提供了一系列用于进行静态调用 (`call_static`)、特殊调用 (`call_special`) 和虚调用 (`call_virtual`) 的...

    JRockit (jrockit-jdk1.6.0_45-R28.2.7-4.1.0-windows-x64.exe)

    它曾经是Oracle公司的一个重要产品,但现在已被Java HotSpot VM所取代,后者是Oracle JDK的一部分。JRockit以其优秀的垃圾收集算法、内存管理和性能分析工具而知名。 JRockit JDK 1.6.0_45是这个版本的特定构建,R...

    JVM与Java体系结构.pdf

    4. **JVM的发展历程**:从早期的Classic VM到Exact VM,再到现在的HotSpot VM,JVM不断优化,引入了如JIT编译器和热点代码探测技术,提升了性能。HotSpot VM在JDK 6、8等版本中成为默认选择,因其能够平衡优化响应...

    Java 运行时环境版本

    - **`java.vm.vendor`**:显示Java虚拟机实现的供应商,如HotSpot、OpenJ9等。 - **`java.vm.name`**:给出了实际运行的Java虚拟机实现的名称,例如“OpenJDK 64-Bit Server VM”。 #### Java 运行时环境规范 - **...

    运行eclipse提示JVM错误的解决

    在使用Eclipse进行开发的过程中,有时可能会遇到JVM(Java虚拟机)错误的问题。这类问题通常表现为启动Eclipse时出现错误提示,例如“jvm terminated. Exit code=-1”。本文将详细介绍这一问题的原因以及具体的解决...

    Java高级面试JVM虚拟机、内存结构、垃圾回收机制

    JVM的种类繁多,包括Sun Classic VM、Exact VM、HotSpot VM、JRockit(由BEA公司开发,后被Oracle收购)、J9(IBM公司的产品)以及阿里巴巴的TaobaoJVM。其中,HotSpot VM是Sun JDK和OpenJDK的标准虚拟机,以其热点...

    java虚拟机介绍

    - **Sun HotSpot VM**:这是目前最为广泛使用的Java虚拟机之一,被集成在Oracle JDK中。HotSpot VM以其高性能和先进的垃圾回收技术而闻名,能够显著提高Java应用程序的运行效率。 - **KVM**:专为嵌入式设备设计的轻...

    深入理解Java虚拟机:JVM高级特性与最佳实践(第3版)1

    书中列举了不同类型的JVM,如经典的HotSpot VM,适用于移动设备的Mobile/Embedded VM,以及针对高性能计算的Azul VM等,展示了Java虚拟机的多样性。 Java虚拟机家族的演变反映了Java技术的发展历程。例如,HotSpot ...

    hsdis-amd64.dylib

    总之,hsdis-amd64.dylib是Java开发者手中的一把利器,它揭示了HotSpot VM JIT编译的神秘面纱,为我们的性能优化之路提供了宝贵的洞察。在JDK1.8中,通过正确配置和使用hsdis-amd64.dylib,我们可以深入探究代码执行...

    Java发展史_&_Java9、10新特性

    - 内置HotSpot VM - 改进RMI对CORBA的兼容性 - 加入动态代理相关类 - JDNI (Java Naming and Directory Interface) - JPDA (Java Platform Debugger Architecture) - **2002年:Java 1.4** - 代号:Merlin -...

    深入理解Java虚拟机1

    随着技术进步,后来的JVM如HotSpot VM引入了即时编译(JIT)技术,提高了运行效率。 在Java虚拟机中,内存管理是非常关键的部分。Java程序中的内存主要分为堆内存和栈内存。堆内存用于存储对象实例,当分配的内存...

Global site tag (gtag.js) - Google Analytics