Java調用C和C++函數時的JNI使用區別:
注意:jni.h頭文件中對於***.c & ***.cpp採用不一樣的定義
在C的定義中,env是一個兩級指針,而在C++的定義中,env是個一級指針
C形式須要對env指針進行雙重deferencing,並且須將env做爲第一個參數傳給jni函數
jclass (JNICALL *GetObjectClass) (JNIEnv *env, jobject obj);
jclass GetObjectClass(jobject obj)
{
return functions->GetObjectClass(this,obj);
}函數
對於***.c
1.jclass test_class = (*env)->GetObjectClass(env, obj);
2.jfieldID id_num = (*env)->GetFieldID(env, test_class, "num", "I");
對於 ***.cpp
1.jclass test_class = env->GetObjectClass(obj);
2.jfieldID id_num = env->GetFieldID(test_class, "num", "I");
在 C 中,
JNI 函數調用由「(*env)->」做前綴,目的是爲了取出函數指針所引用的值。
在 C++ 中,
JNIEnv 類擁有處理函數指針查找的內聯成員函數。
下面將說明這個細微的差別,其中,這兩行代碼訪問同一函數,但每種語言都有各自的語法。
C 語法:jsize len = (*env)->GetArrayLength(env,array);
C++ 語法:jsize len =env->GetArrayLength(array);this
===================指針
對於JNIEnv *env來講,在C中調用:ci
(*env)->NewStringUTF(env, "Hello from JNI!");io
而在C++中若是按照上述調用則會發生'base operand of '->' has non-pointer type '_JNIEnv''錯誤,須要以下調用:function
env->NewStringUTF("Hello from JNI!");class
緣由:參見jni.h中對於JNIEnv的定義:test
#if defined(__cplusplus)object
typedef _JNIEnv JNIEnv;語法
#else
typedef const struct JNINativeInterface* JNIEnv;
#endif