我了解到JNI接口指针(JNIEnv*)仅在当前线程中有效.假设我在本机方法中启动了一个新线程;它如何向Java方法异步发送事件?因为这个新线程不能引用(JNIEnv*).为(JNIEnv*)存储全局变量显然行不通?
我了解到JNI接口指针(JNIEnv*)仅在当前线程中有效.假设我在本机方法中启动了一个新线程;它如何向Java方法异步发送事件?因为这个新线程不能引用(JNIEnv*).为(JNIEnv*)存储全局变量显然行不通?
在JAVA从C++到C++的同步调用中,java已经设置了"环境",但是从一个任意的C++线程中走到另一个方向,它可能不是.
因此,您需要遵循以下步骤
GetEnv
获取JVM环境上下文AttachCurrentThread
CallVoidMethod
按正常方式调用该方法DetachCurrentThread
拆下完整的例子.请注意,我在过go 的blog页上已经详细介绍了这一点
JavaVM* g_vm;
env->GetJavaVM(&g_vm);
void callback(int val) {
JNIEnv * g_env;
// double check it's all ok
int getEnvStat = g_vm->GetEnv((void **)&g_env, JNI_VERSION_1_6);
if (getEnvStat == JNI_EDETACHED) {
std::cout << "GetEnv: not attached" << std::endl;
if (g_vm->AttachCurrentThread((void **) &g_env, NULL) != 0) {
std::cout << "Failed to attach" << std::endl;
}
} else if (getEnvStat == JNI_OK) {
//
} else if (getEnvStat == JNI_EVERSION) {
std::cout << "GetEnv: version not supported" << std::endl;
}
g_env->CallVoidMethod(g_obj, g_mid, val);
if (g_env->ExceptionCheck()) {
g_env->ExceptionDescribe();
}
g_vm->DetachCurrentThread();
}