Experimental options in official builds ?
Krystal Mok
rednaxelafx at gmail.com
Tue Oct 8 22:07:02 PDT 2013
Hi Pierre,
Yes, it is normal. Users would have been warned about using experimental
features "at your own risk" by the -XX:+UnlockExperimentalVMOptions flag,
so it's considered to be okay.
The same goes for diagnostic flags, which is protected by
-XX:+UnlockDiagnosticVMOptions.
- Kris
On Thu, Oct 3, 2013 at 12:27 AM, Pierre Laporte <pierre at pingtimeout.fr>wrote:
> Hi guys
>
> I just discovered that you can unlock experimental VM options in a regular
> build of the JDK.
>
> This page<
> http://www.programmingforliving.com/2013/08/how-to-speed-up-eclipse-sts-startup.html
> >tells
> that unlocking some experimental features can speed up Spring
> ToolSuite. I made some tests on jdk 1.7.0_25 and 1.7.0_40 on linux machines
> and I can indeed modify experimental flags. I thought that experimental
> flags were only for debug build.
>
> Is this normal ?
>
>
> $ java -XX:+PrintFlagsFinal -version | grep experimental
> java version "1.7.0_40"
> OpenJDK Runtime Environment (IcedTea 2.4.2) (ArchLinux build
> 7.u40_2.4.2-1-x86_64)
> OpenJDK 64-Bit Server VM (build 24.0-b56, mixed mode)
>
>
> $ java *-XX:+UnlockExperimentalVMOptions* -XX:+PrintFlagsFinal -version |
> grep experimental
> uintx ArrayAllocatorMallocLimit =
> 18446744073709551615{experimental}
> intx G1ExpandByPercentOfAvailable = 20
> {experimental}
> ccstr G1LogLevel =
> {experimental}
> uintx G1MaxNewSizePercent = 60
> {experimental}
> uintx G1MixedGCLiveThresholdPercent = 65
> {experimental}
> uintx G1NewSizePercent = 5
> {experimental}
> uintx G1OldCSetRegionThresholdPercent = 10
> {experimental}
> bool G1UseConcMarkReferenceProcessing = true
> {experimental}
> bool G1UseParallelRSetScanning = true
> {experimental}
> bool G1UseParallelRSetUpdating = true
> {experimental}
> double ObjectCountCutOffPercent = 0.500000
> {experimental}
> intx PredictedLoadedClassCount = 0
> {experimental}
> bool TrustFinalNonStaticFields = false
> {experimental}
> * bool UnlockExperimentalVMOptions := true
> {experimental} *
> bool UseCriticalCMSThreadPriority = false
> {experimental}
> bool UseCriticalCompilerThreadPriority = false
> {experimental}
> bool UseCriticalJavaThreadPriority = false
> {experimental}
> bool UseMemSetInBOT = true
> {experimental}
> uintx WorkStealingHardSpins = 4096
> {experimental}
> intx WorkStealingSleepMillis = 1
> {experimental}
> uintx WorkStealingSpinToYieldRatio = 10
> {experimental}
> uintx WorkStealingYieldsBeforeSleep = 5000
> {experimental}
> java version "1.7.0_40"
> OpenJDK Runtime Environment (IcedTea 2.4.2) (ArchLinux build
> 7.u40_2.4.2-1-x86_64)
> OpenJDK 64-Bit Server VM (build 24.0-b56, mixed mode)
>
>
> $ java *-XX:+UnlockExperimentalVMOptions* -XX:+PrintFlagsFinal *
> -XX:+TrustFinalNonStaticFields* -version | grep experimental
> uintx ArrayAllocatorMallocLimit =
> 18446744073709551615{experimental}
> intx G1ExpandByPercentOfAvailable = 20
> {experimental}
> ccstr G1LogLevel =
> {experimental}
> uintx G1MaxNewSizePercent = 60
> {experimental}
> uintx G1MixedGCLiveThresholdPercent = 65
> {experimental}
> uintx G1NewSizePercent = 5
> {experimental}
> uintx G1OldCSetRegionThresholdPercent = 10
> {experimental}
> bool G1UseConcMarkReferenceProcessing = true
> {experimental}
> bool G1UseParallelRSetScanning = true
> {experimental}
> bool G1UseParallelRSetUpdating = true
> {experimental}
> double ObjectCountCutOffPercent = 0.500000
> {experimental}
> intx PredictedLoadedClassCount = 0
> {experimental}
> * bool TrustFinalNonStaticFields := true
> {experimental}
> bool UnlockExperimentalVMOptions := true
> {experimental} *
> bool UseCriticalCMSThreadPriority = false
> {experimental}
> bool UseCriticalCompilerThreadPriority = false
> {experimental}
> bool UseCriticalJavaThreadPriority = false
> {experimental}
> bool UseMemSetInBOT = true
> {experimental}
> uintx WorkStealingHardSpins = 4096
> {experimental}
> intx WorkStealingSleepMillis = 1
> {experimental}
> uintx WorkStealingSpinToYieldRatio = 10
> {experimental}
> uintx WorkStealingYieldsBeforeSleep = 5000
> {experimental}
> java version "1.7.0_40"
> OpenJDK Runtime Environment (IcedTea 2.4.2) (ArchLinux build
> 7.u40_2.4.2-1-x86_64)
> OpenJDK 64-Bit Server VM (build 24.0-b56, mixed mode)
>
> --
>
> Pierre Laporte
> @pingtimeout <https://twitter.com/pingtimeout>
> pierre at pingtimeout.fr
> http://www.pingtimeout.fr/
>
More information about the hotspot-dev
mailing list