问题描述
因此,最近我一直在考虑通过C / C ++调用Java方法,但是随之而来的一个重要问题是必须在路径中添加jvm.dll,我一直在想如果发现了通过获取JAVA_HOME并在Linux / MacOS的情况下将“ \ bin \ server”或“ / bin / server”放入jvm.dll,则可以找到它,例如在Windows上使用Windows.h中的LoadLibrary加载函数并使它工作而无需链接任何东西?我可以考虑这种可能性,但无法找到所需的工具,例如,我应该加载哪种方法,它具有哪些参数,返回什么?等等
解决方法
您将只需要使用JNI_CreateJavaVM
来创建JVM,然后从那里通常会得到函数指针的结构,因此对于某些函数,您只需要使用dlsym
。
我使用了dl*
函数,但是在带有LoadLibrary
和GetProcAddress
的Windows上却完全相同。
#include <jni.h> //For the typedefs,struct definitions,...
....
typedef jint (*createJVMFuncPointer_t)(JavaVM **p_vm,void **p_env,void *vm_arg);
....
//I ommitted all checks for errors.
void* handleToLibJVM=dlopen(yourPathToJvmDllOrSo,RTLD_LAZY);
createJVMFuncPointer_t createJVM=(createJVMFuncPointer_t)dlsym(handleToLibJVM,"JNI_CreateJavaVM");
JavaVM *jvm;
JNIEnv *env;
JavaVMOption* options = ...;
//TODO: Initialize options (For things like the classpath and other options)
jint errorCode=createJVM(&jvm,(void**)&env,&vm_args);
//From here you can start looking for your methods written in Java.
jclass cls=(*env)->FindClass(env,"foo/bar/SomeClass");
//Search for method in this class with name baz,taking two ints and returning void.
jmethodID mid=(*env)->GetStaticMethodID(env,cls,"baz","(II)V");
(*env)->CallStaticVoidMethod(env,mid,1,2);
//TODO: Cleanup`(dlclose,free,DestroyJavaVM)