This class determines the version of the Java Virtual Machine. : JVM Tool Interface « Development Class « Java






This class determines the version of the Java Virtual Machine.

       
//package com.javadocking.util;

/**
 * This class determines the version of the Java Virtual Machine.
 * 
 * @author Heidi Rakels.
 */
public class JvmVersionUtil {

  // Static fields.

  /** The integer for java 1.3 versions of the JVM. */
  public static final int VERSION_3_OR_LESS = 3;
  /** The integer for java 5 versions of the JVM. */
  public static final int VERSION_4_or_5 = 4;
  /** The integer for java 6 versions of the JVM. */
  public static final int VERSION_6_OR_MORE = 6;

  /** The float for java 4 versions of the JVM. */
  private static final float VERSION_4 = 1.4f;
  /** The integer for java 6 versions of the JVM. */
  private static final float VERSION_6 = 1.6f;

  // Public static methods.

  /**
   * Gets the version of the JVM.
   * 
   * @return The integer that corresponds with the version of the JVM. This
   *         can be VERSION_3_OR_LESS,VERSION_4_or_5, VERSION_6_OR_MORE.
   * @throws IllegalStateException
   *             If the system property <code>java.version</code> does not
   *             start with a x.x. x should be a number.
   */
  public static int getVersion() {

    // Get the system property java.vm.version.
    String jVersion = System.getProperty("java.version");

    // Get the version number.
    int pointPosition = jVersion.indexOf(".");
    if (pointPosition > 0) {
      if (jVersion.length() >= pointPosition + 2) {
        String version = jVersion.substring(0, pointPosition + 2);

        try {
          float versionNumber = Float.parseFloat(version);
          if (versionNumber < VERSION_4) {
            return VERSION_3_OR_LESS;
          }
          if (versionNumber < VERSION_6) {
            return VERSION_4_or_5;
          } else {
            return VERSION_6_OR_MORE;
          }
        } catch (NumberFormatException exception) {
          throw new IllegalStateException("Unknown java version ["
              + jVersion + "].");
        }
      }
    }

    throw new IllegalStateException("Unknown java version [" + jVersion
        + "].");

  }

  // Test.

  // public static void main(String[] args) {
  //
  // String version = System.getProperty("java.vm.version");
  // System.out.println("Version number: " + getVersion());
  // System.out.println("Version string: " + version);
  //
  // }

  // Private constructor.

  private JvmVersionUtil() {
  }
}

   
    
    
    
    
    
    
  








Related examples in the same category

1.Set the memory available to the JVM
2.jconsole plugin
3.This agent library can be used to track threads that wait on monitors.
4.Check the version of the interface being used
5.Track method call and return counts
6.Inject code at method calls
7.Do some very basic bytecode insertion (BCI) of class files
8.Byte Code Instrumentation (BCI)
9.How to get an easy view of the heap in terms of total object count and space used
10.Track object allocations
11.This agent library can be used to track garbage collection events
12.JVM Tool Interface agent utilities
13.Java Platform Debugger Architecture
14.Memory related
15.System memory
16.Floating Point Arithmetic
17.Logic and Integer Arithmetic
18.JVM Simulator
19.Stack memory view
20.JVM memory util
21.Generate a listing of the most trusted certification authorities used by your JVM
22.Java version Util