JNI 线程模型?

当我从 Java 调用 C/C++时,JavaVM 或 JNI 是否创建了一个新线程,以便在我的 Java 线程等待时运行 C/C++ 代码?我问这个是因为我的C / C++代码在GPU上运行一些东西,我需要检查特定的缓冲区才能得到结果。一旦我有了结果,我需要再次调用我的Java函数。

因此,我正在考虑在C++端创建一个线程,该线程不断检查缓冲区,一旦有一些可用数据,就会回调Java端。


答案 1

JNI 不会在幕后创建任何新线程。本机函数在与调用本机函数的 java 方法相同的线程中执行。反之亦然,当本机代码调用 java 方法时,java 方法在与调用该方法的本机代码相同的线程中执行。

它有后果 - 本机函数调用在本机函数返回时返回到 java 代码,当调用的 java 方法返回时,本机代码继续执行。

当本机代码执行应在单独线程中运行的处理时,必须显式创建该线程。您可以创建一个新的 java 线程,然后从此专用线程调用本机方法。或者,您可以在本机代码中创建新的本机线程,启动它并从本机函数返回。

// Call a native function in a dedicated java thread
native void cFunction();
...
new Thread() {
    public void run() {
        cFunction();
    }
};

// Create a native thread - java part
native void cFunction()
...
cFunction();

//  Create a native thread - C part
void *processing_function(void *p);
JNIEXPORT void JNICALL Java____cFunction(JNIEnv *e, jobject obj) {
    pthread_t t;
    pthread_create(&t, NULL, processing_function, NULL);    
}

如果您使用第二个变体,并且想要从本机创建的线程调用 java 回调,则必须将该线程附加到 JVM。怎么办?请参阅 JNI 附加/分离线程内存管理 ...


答案 2