| 选项 | 默认值与限制 | 描述 |
| -XX:-AllowUserSignalHandlers | 限于Linux和Solaris,默认不启用 | 允许为java进程安装信号处理器。 Java信号处理相关知识,详见 http://kenwublog.com/java-asynchronous-notify-based-on-signal |
| -XX:-DisableExplicitGC | 默认不启用 | 禁止在运行期显式地调用 System.gc()。
开启该选项后,GC的触发时机将由Garbage Collector全权掌控。 例如RMI就在多数用户毫不知情的情况下,显示地调用GC来防止自身OOM。 请仔细权衡禁用带来的影响。 |
| -XX:-RelaxAccessControlCheck | 默认不启用 | 在Class校验器中,放松对访问控制的检查。
作用与reflection里的setAccessible类似。 |
| -XX:-UseConcMarkSweepGC | 默认不启用 | 启用CMS低停顿垃圾收集器。 |
| -XX:-UseParallelGC | -server时启用
其他情况下,默认不启用 |
策略为新生代使用并行清除,年老代使用单线程Mark-Sweep-Compact的垃圾收集器。 |
| -XX:-UseParallelOldGC | 默认不启用 | 策略为老年代和新生代都使用并行清除的垃圾收集器。 |
| -XX:-UseSerialGC | -client时启用
其他情况下,默认不启用 |
使用串行垃圾收集器。 |
| -XX:+UseSplitVerifier | java5默认不启用
java6默认启用 |
使用新的Class类型校验器 。 新Class类型校验器有什么特点? 新Class类型校验器,将老的校验步骤拆分成了两步: 1,类型推断。 2,类型校验。 新类型校验器通过在javac编译时嵌入类型信息到bytecode中,省略了类型推断这一步,从而提升了classloader的性能。 Classload顺序(供参考) |
| -XX:+FailOverToOldVerifier | Java6新引入选项,默认启用 | 如果新的Class校验器检查失败,则使用老的校验器。
为什么会失败? 因为JDK6最高向下兼容到JDK1.2,而JDK1.2的class info 与JDK6的info存在较大的差异,所以新校验器可能会出现校验失败的情况。 |
| -XX:+HandlePromotionFailure | java5以前是默认不启用,java6默认启用 | 关闭新生代收集担保。 什么是新生代收集担保? 在一次理想化的minor gc中,Eden和First Survivor中的活跃对象会被复制到Second Survivor。 然而,Second Survivor不一定能容纳下所有从E和F区copy过来的活跃对象。 为了确保minor gc能够顺利完成,GC需要在年老代中额外保留一块足以容纳所有活跃对象的内存空间。 为什么要关闭新生代收集担保? 为了确保极端情况的发生,GC参考了最坏情况下的新生代内存占用,即Eden+First Survivor。 这种策略无疑是在浪费年老代内存,从时序角度看,还会提前触发Full GC。 为了避免如上情况的发生,JVM允许开发者手动关闭新生代收集担保。 在开启本选项后,minor gc将不再提供新生代收集担保,而是在出现survior或年老代不够用时,抛出promotion failed异常。 |
| -XX:+UseSpinning | java1.4.2和1.5需要手动启用, java6默认已启用 | 启用多线程自旋锁优化。 自旋锁优化原理 大家知道,Java的多线程安全是基于Lock机制实现的,而Lock的性能往往不如人意。 为了避免进入OS互斥,Java6的开发者们提出了自旋锁优化。 自旋锁优化的原理是在线程进入OS互斥前,通过CAS自旋一定的次数来检测锁的释放。 如果在自旋次数未达到预设值前锁已被释放,则当前线程会立即持有该锁。 CAS检测锁的原理详见: http://kenwublog.com/theory-of-lightweight-locking-upon-cas |
| -XX:PreBlockSpin=10 | -XX:+UseSpinning 必须先启用,对于java6来说已经默认启用了,这里默认自旋10次 | 控制多线程自旋锁优化的自旋次数。(什么是自旋锁优化?见 -XX:+UseSpinning 处的描述) 关联选项: -XX:+UseSpinning |
| -XX:+ScavengeBeforeFullGC | 默认启用 | 在Full GC前触发一次Minor GC。 |
| -XX:+UseGCOverheadLimit | 默认启用 | 限制GC的运行时间。如果GC耗时过长,就抛OOM。 |
| -XX:+UseTLAB | 1.4.2以前和使用-client选项时,默认不启用,其余版本默认启用 | 启用线程本地缓存区(Thread Local)。 |
| -XX:+UseThreadPriorities | 默认启用 | 使用本地线程的优先级。 |
| -XX:+UseAltSigs | 限于Solaris,默认启用 | 为了防止与其他发送信号的应用程序冲突,允许使用候补信号替代 SIGUSR1和SIGUSR2。 |
| -XX:+UseBoundThreads | 限于Solaris, 默认启用 | 绑定所有的用户线程到内核线程。 减少线程进入饥饿状态(得不到任何cpu time)的次数。 |
| -XX:+UseLWPSynchronization | 限于solaris,默认启用 | 使用轻量级进程(内核线程)替换线程同步。 |
| -XX:+MaxFDLimit | 限于Solaris,默认启用 | 设置java进程可用文件描述符为操作系统允许的最大值。 |
| -XX:+UseVMInterruptibleIO | 限于solaris,默认启用 | 在solaris中,允许运行时中断线程 。 |
Java6 JVM参数调试行为篇
You can follow any responses to this entry through the RSS 2.0 | You can leave a response or trackback from your own site.
Comments