Вопрос по java – Все возможные значения os.arch в 32-битной JRE и в 64-битной JRE

27

Мне нужна последняя компиляция всех возможных значений свойства os.arch в JRE 1.6 для Linux, Solaris и Windows. Если возможно, пожалуйста, укажите источник ваших выводов. Мне нужны эти значения для выбора ресурсов в моем файле JNLP. В основном мне нужно назначить другую память JVM в зависимости от того, является ли JRE 32-битным или 64-битным. Ждет вашего ответа. Спасибо

Ваш Ответ

2   ответа
9

Смотря наjava.lang.System вы можете видеть, что свойства инициализируются вinitializeSystemClass метод с использованиемinitProperties метод, который опирается на нативный код, используяJNI:

private static native Properties initProperties(Properties props);

/**
 * Initialize the system class.  Called after thread initialization.
 */
private static void initializeSystemClass() {

    // VM might invoke JNU_NewStringPlatform() to set those encoding
    // sensitive properties (user.home, user.name, boot.class.path, etc.)
    // during "props" initialization, in which it may need access, via
    // System.getProperty(), to the related system encoding property that
    // have been initialized (put into "props") at early stage of the
    // initialization. So make sure the "props" is available at the
    // very beginning of the initialization and all system properties to
    // be put into it directly.
    props = new Properties();
    initProperties(props);  // initialized by the VM
    ...
    ...
}

Если вы проверите источник этого собственного кода, вызванного изinitProperties для разных платформ вы можете увидеть возможные значенияos.arch системное свойство. Так что сделайте это шаг за шагом:

Первый взгляд наSystem.c чтобы увидетьJNI метод вызывается изjava.lang.System.initProperties, ОтSystem.c

JNIEXPORT jobject JNICALL
Java_java_lang_System_initProperties(JNIEnv *env, jclass cla, jobject props)
{
    char buf[128];
    java_props_t *sprops = GetJavaProperties(env);
    jmethodID putID = (*env)->GetMethodID(env,
                                          (*env)->GetObjectClass(env, props),
                                          "put",
            "(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;");

    if (sprops == NULL || putID == NULL ) return NULL;

    PUTPROP(props, "java.specification.version",
            JDK_MAJOR_VERSION "." JDK_MINOR_VERSION);
    PUTPROP(props, "java.specification.name",
            "Java Platform API Specification");
    PUTPROP(props, "java.specification.vendor", "Sun Microsystems Inc.");

    PUTPROP(props, "java.version", RELEASE);
    PUTPROP(props, "java.vendor", VENDOR);
    PUTPROP(props, "java.vendor.url", VENDOR_URL);
    PUTPROP(props, "java.vendor.url.bug", VENDOR_URL_BUG);

    ...

    /* os properties */
    PUTPROP(props, "os.name", sprops->os_name);
    PUTPROP(props, "os.version", sprops->os_version);

    // HERE IS THE `os.arch` PROPERTY :)

    PUTPROP(props, "os.arch", sprops->os_arch);

Так как вы можете видетьos.arch происходит отPUTPROP(props, "os.arch", sprops->os_arch); иsprops это достигается с помощьюjava_props_t *sprops = GetJavaProperties(env);, так что давайте посмотрим наGetJavaProperties(env)этот метод определен вjava_props.h как:

java_props_t *GetJavaProperties(JNIEnv *env);

И реализация кажется зависит от ОС.

Итак, наконец, ищем конкретную реализацию дляGetJavaProperties; in Windows the possible values which this property can take are ia64, amd64, x86, или жеunknown, Вы можете видеть изjava_props_md.c file :

#if _M_IA64
        sprops.os_arch = "ia64";
#elif _M_AMD64
        sprops.os_arch = "amd64";
#elif _X86_
        sprops.os_arch = "x86";
#else
        sprops.os_arch = "unknown";
#endif

Для Solaris кажется более сложным, поскольку значение свойства в собственном коде происходит от макроса, определенного вjava_props_md.c специфичен для соляриса как:

sprops.os_arch = ARCHPROPNAME;

И этот макрос определен в следующемMakefile как:

OTHER_CPPFLAGS += -DARCHPROPNAME='"$(ARCHPROP)"'

Таким образом, похоже, что это происходит из среды, в которой он скомпилирован (извините, я не эксперт по Си, я просто догадываюсь, однако, может быть, я вам немного помогу)

В папке Linux вsrc/linux/native/ здесь нетjava_props_md.c поэтому я предполагаю, что в этом случае возьмите тот же источник, что и у Solaris (я снова догадываюсь ...).

NOTE: Я использую версию 1.6, чтобы получить эти значения, однако новые значения могут быть добавлены в новейших версиях Java, поэтому проверьте нужную версию.

Надеюсь, поможет,

Error: User Rate Limit Exceededos.archError: User Rate Limit Exceeded:).
Error: User Rate Limit Exceededopen-endedError: User Rate Limit Exceeded
8

подобный приведенному ниже, чтобы узнать os и его архив.

import java.util.HashMap;
import java.util.Map;

import org.apache.commons.lang.SystemUtils;


public class PlatformDetection {
    private String os;
    private String arch;
    public static String OS_WINDOWS = "windows";
    public static String OS_OSX = "osx";
    public static String OS_SOLARIS = "solaris";
    public static String OS_LINUX = "linux";
    public static String ARCH_PPC = "ppc";
    public static String ARCH_X86_32 = "x86_32";
    public static String ARCH_X86_64 = "x86_64";

    public PlatformDetection() {
        // resolve OS
        if (SystemUtils.IS_OS_WINDOWS) {
            this.os = OS_WINDOWS;
        } else if (SystemUtils.IS_OS_MAC_OSX) {
            this.os = OS_OSX;
        } else if (SystemUtils.IS_OS_SOLARIS) {
            this.os = OS_SOLARIS;
        } else if (SystemUtils.IS_OS_LINUX) {
            this.os = OS_LINUX;
        } else {
            throw new IllegalArgumentException("Unknown operating system " + SystemUtils.OS_NAME);
        }

        // resolve architecture
        Map<String, String> archMap = new HashMap<String, String>();
        archMap.put("x86", ARCH_X86_32);
        archMap.put("i386", ARCH_X86_32);
        archMap.put("i486", ARCH_X86_32);
        archMap.put("i586", ARCH_X86_32);
        archMap.put("i686", ARCH_X86_32);
        archMap.put("x86_64", ARCH_X86_64);
        archMap.put("amd64", ARCH_X86_64);
        archMap.put("powerpc", ARCH_PPC);
        this.arch = archMap.get(SystemUtils.OS_ARCH);
        if (this.arch == null) {
            throw new IllegalArgumentException("Unknown architecture " + SystemUtils.OS_ARCH);
        }
    }

    public String getOs() {
        return os;
    }

    public String getArch() {
        return arch;
    }

    public void setArch(String arch) {
        this.arch = arch;
    }

    public void setOs(String os) {
        this.os = os;
    }

    public String toString() {

        return os + "_" + arch;
    }
}

См. Ниже ссылки

https://github.com/trustin/os-maven-plugin/blob/master/src/main/java/kr/motd/maven/os/Detector.java

https://github.com/rachelxqy/EligibilityCriteriaModeling/blob/57001f6d86084f074f4ca6aaff157e93ef6abf95/src/main/java/edu/mayo/bmi/medtagger/ml/util/PlatformDetection.java

Error: User Rate Limit Exceededos.archError: User Rate Limit ExceededpowerpcError: User Rate Limit ExceededppcError: User Rate Limit Exceeded

Похожие вопросы