mirror of
https://github.com/corda/corda.git
synced 2025-01-07 13:38:47 +00:00
avoid calling unrelated JNI methods during class initialization
The main goal here is to avoid making JNI calls from code that really shouldn't need JNI (e.g. before this patch, ArrayList.add called Math.max, which called Math.<clinit>, which called Random.<init>, which called System.currentTimeMillis). Besides following the "pay for only what you need" principle, this change ensures we can call LambdaMetaFactory methods during AOT compilation with a minimal VM (i.e. without compiling in JNI methods we don't need).
This commit is contained in:
parent
9f70aa753e
commit
9b2a02e92b
@ -15,7 +15,10 @@ import java.util.Random;
|
|||||||
public final class Math {
|
public final class Math {
|
||||||
public static final double E = 2.718281828459045;
|
public static final double E = 2.718281828459045;
|
||||||
public static final double PI = 3.141592653589793;
|
public static final double PI = 3.141592653589793;
|
||||||
private static final Random random = new Random();
|
|
||||||
|
private static class Static {
|
||||||
|
public static final Random random = new Random();
|
||||||
|
}
|
||||||
|
|
||||||
private Math() { }
|
private Math() { }
|
||||||
|
|
||||||
@ -84,7 +87,7 @@ public final class Math {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public static double random() {
|
public static double random() {
|
||||||
return random.nextDouble();
|
return Static.random.nextDouble();
|
||||||
}
|
}
|
||||||
|
|
||||||
public static native double floor(double v);
|
public static native double floor(double v);
|
||||||
|
@ -22,7 +22,9 @@ import java.util.Hashtable;
|
|||||||
import java.util.Properties;
|
import java.util.Properties;
|
||||||
|
|
||||||
public abstract class System {
|
public abstract class System {
|
||||||
private static final long NanoTimeBaseInMillis = currentTimeMillis();
|
private static class NanoTime {
|
||||||
|
public static final long BaseInMillis = currentTimeMillis();
|
||||||
|
}
|
||||||
|
|
||||||
private static class Static {
|
private static class Static {
|
||||||
public static Properties properties = makeProperties();
|
public static Properties properties = makeProperties();
|
||||||
@ -94,7 +96,7 @@ public abstract class System {
|
|||||||
public static native int identityHashCode(Object o);
|
public static native int identityHashCode(Object o);
|
||||||
|
|
||||||
public static long nanoTime() {
|
public static long nanoTime() {
|
||||||
return (currentTimeMillis() - NanoTimeBaseInMillis) * 1000000;
|
return (currentTimeMillis() - NanoTime.BaseInMillis) * 1000000;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static String mapLibraryName(String name) {
|
public static String mapLibraryName(String name) {
|
||||||
|
Loading…
Reference in New Issue
Block a user