Odpowiedzi:
Te artykuły wydają się sugerować, że sprawdzanie prefiksu 1.5
lub 1.6
prefiksu powinno działać, ponieważ jest zgodne z konwencją nazewnictwa poprawnej wersji.
java.version
właściwość systemowa”java.version
właściwość systemowa”java.version
to właściwość systemowa, która istnieje w każdej maszynie JVM. Istnieją dwa możliwe formaty:
1.6.0_23
, 1.7.0
, 1.7.0_80
,1.8.0_211
9.0.1
, 11.0.4
, 12
,12.0.1
Oto sztuczka, aby wyodrębnić wersję główną: Jeśli jest to 1.x.y_z
ciąg wersji, wyodrębnij znak pod indeksem 2 ciągu. Jeśli jest to x.y.z
ciąg wersji, przytnij ciąg do pierwszego znaku kropki, jeśli taki istnieje.
private static int getVersion() {
String version = System.getProperty("java.version");
if(version.startsWith("1.")) {
version = version.substring(2, 3);
} else {
int dot = version.indexOf(".");
if(dot != -1) { version = version.substring(0, dot); }
} return Integer.parseInt(version);
}
Teraz możesz sprawdzić wersję o wiele wygodniej:
if(getVersion() < 6) {
// ...
}
double version = 1.6
i Double.parseDouble("1.6")
nadal powinien dawać ten sam wzór bitowy, prawda? Ponieważ nie wykonujemy arytmetyki na liczbie (tylko proste porównanie), funkcja even == będzie działać zgodnie z oczekiwaniami.
A co z pobieraniem wersji z meta informacji o pakiecie:
String version = Runtime.class.getPackage().getImplementationVersion();
Wyświetla coś takiego:
1.7.0_13
Runtime.class.getPackage().getSpecificationVersion()
Runtime.class.getPackage().getImplementationVersion()
wydaje się wracać null
na JDK9.
Runtime.version()
Od wersji Java 9 możesz użyć Runtime.version()
, która zwraca Runtime.Version
:
Runtime.Version version = Runtime.version();
Najprostszy sposób ( java.specification.version ):
double version = Double.parseDouble(System.getProperty("java.specification.version"));
if (version == 1.5) {
// 1.5 specific code
} else {
// ...
}
lub coś takiego ( java.version ):
String[] javaVersionElements = System.getProperty("java.version").split("\\.");
int major = Integer.parseInt(javaVersionElements[1]);
if (major == 5) {
// 1.5 specific code
} else {
// ...
}
lub jeśli chcesz to wszystko zepsuć ( java.runtime.version ):
String discard, major, minor, update, build;
String[] javaVersionElements = System.getProperty("java.runtime.version").split("\\.|_|-b");
discard = javaVersionElements[0];
major = javaVersionElements[1];
minor = javaVersionElements[2];
update = javaVersionElements[3];
build = javaVersionElements[4];
Tylko uwaga, że w Javie 9 i nowszych konwencja nazewnictwa jest inna. System.getProperty("java.version")
zwraca "9"
raczej niż "1.9"
.
Nie działa, trzeba --pos
ocenić podwójnie:
String version = System.getProperty("java.version");
System.out.println("version:" + version);
int pos = 0, count = 0;
for (; pos < version.length() && count < 2; pos++) {
if (version.charAt(pos) == '.') {
count++;
}
}
--pos; //EVALUATE double
double dversion = Double.parseDouble(version.substring(0, pos));
System.out.println("dversion:" + dversion);
return dversion;
}
Przykład dla Apache Commons Lang:
import org.apache.commons.lang.SystemUtils;
Float version = SystemUtils.JAVA_VERSION_FLOAT;
if (version < 1.4f) {
// legacy
} else if (SystemUtils.IS_JAVA_1_5) {
// 1.5 specific code
} else if (SystemUtils.isJavaVersionAtLeast(1.6f)) {
// 1.6 compatible code
} else {
// dodgy clause to catch 1.4 :)
}
version < 1.4f
... Co się stanie, kiedy version = 1.4f
?
version <= 1.4f
.. Niestety SystemUtils
nie podaje isJavaVersionLessThan
metody, ale potem (na szczęście) możesz również umieścić starszy kod w else
bloku, który jest bardziej przejrzysty.
1.4f
wrócić do starszego kodu?
if (SystemUtils.IS_JAVA_1_5) { /* 1.5 specific code */ } else if (SystemUtils.isJavaVersionAtLeast(1.6f)) { /* modern code */ } else { /* fall back to legacy code */ }
. Konkretny kod powyżej, kod ogólny poniżej, kod awaryjny na samym dole.
Oto implementacja w JOSM :
/**
* Returns the Java version as an int value.
* @return the Java version as an int value (8, 9, etc.)
* @since 12130
*/
public static int getJavaVersion() {
String version = System.getProperty("java.version");
if (version.startsWith("1.")) {
version = version.substring(2);
}
// Allow these formats:
// 1.8.0_72-ea
// 9-ea
// 9
// 9.0.1
int dotPos = version.indexOf('.');
int dashPos = version.indexOf('-');
return Integer.parseInt(version.substring(0,
dotPos > -1 ? dotPos : dashPos > -1 ? dashPos : 1));
}
Nie wiem, jak to sprawdzić, ale to: http://java.sun.com/j2se/1.5.0/docs/api/java/lang/System.html#getProperties () "oznacza, że" java.version "jest standardową właściwością systemową, więc spodziewałbym się, że tak współpracować z innymi maszynami JVM.
Oto odpowiedź z @mvanle, przekonwertowana na Scala:
scala> val Array(javaVerPrefix, javaVerMajor, javaVerMinor, _, _) = System.getProperty("java.runtime.version").split("\\.|_|-b")
javaVerPrefix: String = 1
javaVerMajor: String = 8
javaVerMinor: String = 0