public class Main { static class SuperClass { protected static int getVar(int w) { return w & 0xF; } } static class SubClass extends SuperClass { final int getVarDirect(int w) { return w & 0xF; } public void testDirect(int max) { for (int i = 0; i < max; ++i) { getVarDirect(max); } } public void testStatic(int max) { for (int i = 0; i < max; ++i) { getVar(max); } } } static public void main(String[] args) throws Exception { boolean timing = (args.length >= 1) && args[0].equals("--timing"); run(timing); } static int testBasis(int iterations) { (new SubClass()).testDirect(iterations); return iterations; } static int testStatic(int iterations) { (new SubClass()).testStatic(iterations); return iterations; } static public void run(boolean timing) { long time0 = System.nanoTime(); int count1 = testBasis(50000000); long time1 = System.nanoTime(); int count2 = testStatic(50000000); long time2 = System.nanoTime(); System.out.println("basis: performed " + count1 + " iterations"); System.out.println("test1: performed " + count2 + " iterations"); double basisMsec = (time1 - time0) / (double) count1 / 1000000; double msec1 = (time2 - time1) / (double) count2 / 1000000; if (msec1 < basisMsec * 5) { System.out.println("Timing is acceptable."); } else { System.out.println("Iterations are taking too long!"); timing = true; } if (timing) { System.out.printf("basis time: %.3g msec\n", basisMsec); System.out.printf("test1: %.3g msec per iteration\n", msec1); } } }