[英]Are JNI native invocations from different Java threads sequentialized?
我正在制作Windows JNI .dll。 我試圖確定JVM是否可以對同一本機函數進行並發調用。 這是我編寫的Java代碼:
public class TestThreads implements Runnable
{
public void run()
{
MyJNIClass.f(); // Call 'native' static member function
}
public static void main(String[] args)
{
for (int k = 0; k < 20; ++k)
new Thread(new TestThreads()).run();
}
}
在本地方面,函數MyJNIClass.f()
的實現如下:
#include <jni.h>
#include <windows.h>
#include <iostream>
extern "C"
{
JNIEXPORT void JNICALL Java_MyJNIClass_f(JNIEnv * env, jclass clazz)
{
std::cout << GetCurrentThreadId() << ", " << GetCurrentThread() << std::endl;
Sleep(500);
}
}
本機函數的輸出表明所有調用都從同一Win32線程運行:
5196,0xfffffffe
5196,0xfffffffe
5196,0xfffffffe
5196,0xfffffffe
5196,0xfffffffe
5196,0xfffffffe
5196,0xfffffffe
5196,0xfffffffe
5196,0xfffffffe
...
...這些行中的每一行都在上一行之后的半秒內彈出。
因此,唯一途徑是使本機端使用多個線程(例如JVM)在本機/ DLL端創建工作線程,然后立即返回!
您只有一個線程是為您創建的“主”線程。
我懷疑您打算致電start();
哪個調用run();
在新線程中,而不是重用當前線程。
我還要補充一點,JNI未序列化,您可以從多個線程進行調用。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.