JNI_CreateJavaVM 采用 OpenJDK 11.0.8 失败
JNI_CreateJavaVM fails with Adopt OpenJDK 11.0.8
我们的 64 位 C 程序使用 JNI 实例化 JVM。目前我们正在使用 Adopt Open JDK 8.0.1920.12 并且一切正常。现在我们正在尝试迁移到 Adopt Open JDK 11.0.8.0。使用那个时,JNI_CreateJavaVM 总是 returns -1.
我做的基本上是
a) 下载 JDK(文件 OpenJDK11U-jre_x64_windows_hotspot_11.0.8_10.zip)
b) 将其内容放入先前包含Java 8 JDK 的文件夹中。这个文件夹可以在PATH环境变量中找到
我们的代码是:
char* ipV4 = "-Djava.net.preferIPv4Stack=true";
opts[numopts++].optionString = ipV4;
// get path pointing to our Java classes
classpath = WfBuildJVMClasspathStr();
opts[numopts++].optionString = classpath;
//make sure we notify the JVM we are a service
sprintf(servicearg, "-Xrs");
opts[numopts++].optionString = servicearg;
vm_args.version = JNI_VERSION_1_2;
vm_args.options = opts;
vm_args.nOptions = numopts;
vm_args.ignoreUnrecognized = true;
status = JNI_CreateJavaVM(&jvm, (void **)&envP, &vm_args);
或者我也尝试用以下代码替换最后一行:
char JVMExe[STRPATH + 1];
// make up path to the <JDK install>\bin\server\jvm.dll
sprintf(JVMExe, "%s\jvm.dll", WF.JVMDir);
HINSTANCE hinstLib = LoadLibrary(TEXT(JVMExe));
typedef jint(JNICALL *PtrCreateJavaVM)(JavaVM **, void **, void *);
PtrCreateJavaVM ptrCreateJavaVM = (PtrCreateJavaVM)GetProcAddress(hinstLib, "JNI_CreateJavaVM");
status = ptrCreateJavaVM(&jvm, (void**)&envP, &vm_args);
不幸的是,结果相同(阴性)。
知道我做错了什么吗?
我找到了问题的原因。我创建了一个最小的命令行 exe 并让它写入控制台。我收到此错误消息:
/lib/ext 存在,不再支持扩展机制;请改用 -classpath。
在查找时,我发现了这样的文章:
https://docs.oracle.com/javase/9/migrate/toc.htm#JSMIG-GUID-2C896CA8-927C-4381-A737-B1D81D964B7B
将我的 JRE 的“lib”目录中的“ext”文件夹重命名为例如“ext_go_away”JNI_CreateJavaVM 成功。
我们的 64 位 C 程序使用 JNI 实例化 JVM。目前我们正在使用 Adopt Open JDK 8.0.1920.12 并且一切正常。现在我们正在尝试迁移到 Adopt Open JDK 11.0.8.0。使用那个时,JNI_CreateJavaVM 总是 returns -1.
我做的基本上是 a) 下载 JDK(文件 OpenJDK11U-jre_x64_windows_hotspot_11.0.8_10.zip) b) 将其内容放入先前包含Java 8 JDK 的文件夹中。这个文件夹可以在PATH环境变量中找到
我们的代码是:
char* ipV4 = "-Djava.net.preferIPv4Stack=true";
opts[numopts++].optionString = ipV4;
// get path pointing to our Java classes
classpath = WfBuildJVMClasspathStr();
opts[numopts++].optionString = classpath;
//make sure we notify the JVM we are a service
sprintf(servicearg, "-Xrs");
opts[numopts++].optionString = servicearg;
vm_args.version = JNI_VERSION_1_2;
vm_args.options = opts;
vm_args.nOptions = numopts;
vm_args.ignoreUnrecognized = true;
status = JNI_CreateJavaVM(&jvm, (void **)&envP, &vm_args);
或者我也尝试用以下代码替换最后一行:
char JVMExe[STRPATH + 1];
// make up path to the <JDK install>\bin\server\jvm.dll
sprintf(JVMExe, "%s\jvm.dll", WF.JVMDir);
HINSTANCE hinstLib = LoadLibrary(TEXT(JVMExe));
typedef jint(JNICALL *PtrCreateJavaVM)(JavaVM **, void **, void *);
PtrCreateJavaVM ptrCreateJavaVM = (PtrCreateJavaVM)GetProcAddress(hinstLib, "JNI_CreateJavaVM");
status = ptrCreateJavaVM(&jvm, (void**)&envP, &vm_args);
不幸的是,结果相同(阴性)。
知道我做错了什么吗?
我找到了问题的原因。我创建了一个最小的命令行 exe 并让它写入控制台。我收到此错误消息:
在查找时,我发现了这样的文章: https://docs.oracle.com/javase/9/migrate/toc.htm#JSMIG-GUID-2C896CA8-927C-4381-A737-B1D81D964B7B
将我的 JRE 的“lib”目录中的“ext”文件夹重命名为例如“ext_go_away”JNI_CreateJavaVM 成功。