Mercurial > hg > gc-bench
view src/main/java/org/openjdk/gcbench/MaxHeapDetector.java @ 44:25f22a0b9311
Step heap sizes as power of two.
author | shade |
---|---|
date | Thu, 08 Dec 2016 11:30:54 +0100 |
parents | 985f404de0a8 |
children |
line wrap: on
line source
package org.openjdk.gcbench; import org.openjdk.gcbench.util.Dummy; import org.openjdk.jmh.runner.Runner; import org.openjdk.jmh.runner.RunnerException; import org.openjdk.jmh.runner.options.Options; import org.openjdk.jmh.runner.options.OptionsBuilder; import org.openjdk.jmh.runner.options.VerboseMode; import java.io.PrintWriter; public class MaxHeapDetector { public static int MAX_HEAP; public static void override(int value) { MAX_HEAP = value; } public static void init(PrintWriter pw) { int baseHeapMB = 1000; int latestSuccessMB = 0; boolean progress; do { progress = false; for (int incr = 1000; incr < Integer.MAX_VALUE; incr *= 2) { int heapGB = baseHeapMB + incr; pw.print(heapGB + "? "); pw.flush(); Options opts = new OptionsBuilder() .include(Dummy.class.getCanonicalName()) .threads(1) .jvmArgsAppend("-Xmx" + heapGB + "m", "-Xms" + heapGB + "m", "-XX:+AlwaysPreTouch") .verbosity(VerboseMode.SILENT) .build(); try { new Runner(opts).runSingle(); latestSuccessMB = heapGB; progress = true; } catch (RunnerException e) { baseHeapMB = latestSuccessMB; break; } } } while (progress); pw.println(); pw.println("Max heap size is " + latestSuccessMB + " Mb"); pw.println(); MAX_HEAP = latestSuccessMB; } }