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);
        }
    }
}