参数,它们有一个共同的特点,包含JNIEnv *――它是一个接口指针,用于定位函数表中的函数!
在JNI规范中一般称 为 “Interface Pointer”。看到这儿好像和过程调用很类似了!是的,JNI中
的操作过程,就是面向过程的!后面的jobject是 一个指向该类的指针,类似与C语言中的this。这个
第二个参数是变化的,当该方法为类的实例方法时该参数为jobject;当该方法为类方法(即静态方法)
时该参数为jclass,指向该类的class。
根据不同方法前缀生成的头文件比较如下:
1、static与非static的比较:
- /*
- * Class: com_nedu_jni_helloword_HeaderFile
- * Method: doInt
- * Signature: (DD)I
- */
- JNIEXPORT jint JNICALL Java_com_nedu_jni_helloword_HeaderFile_doInt__DD
- (JNIEnv *, <span style="background-color: rgb(255, 0, 0);">jobject</span>, jdouble, jdouble);
- /*
- * Class: com_nedu_jni_helloword_HeaderFile
- * Method: doInt
- * Signature: (DDD)I
- */
- JNIEXPORT jint JNICALL Java_com_nedu_jni_helloword_HeaderFile_doInt__DDD
- (JNIEnv *, <span style="color:#000000;background-color: rgb(255, 0, 0);">jclass</span>, jdouble, jdouble, jdouble);
第一个是非static方法,第二个是static方法,不同点如上红色标记。其中的不同将在以后提到。
2、 private、friendly、protected以及public这些方法限制符不会在JNI的头文件中出现。这些访问修饰符只有在其它类
使用这些方法时有效!JNI中不关心此修饰符
#if defined(__cplusplus)//这里表示是c++用的 typedef _JNIEnv JNIEnv;//这是native方法的第一个参数 typedef _JavaVM JavaVM;//这个是虚拟机 #else typedef const struct JNINativeInterface* JNIEnv; typedef const struct JNIInvokeInterface* JavaVM; #endif struct JNINativeInterface{ //具体内容省略, //它们都是一些函数指针,这个结构体,每个native方法的第一个参数JNIEnv env 就是它自己 }; 另外注意一下 //这两个方法,是由java虚拟机调用的,它传入一个vm,通过vm我们可以得到JNIEnv,通过JNIEnv我们可以得到 //java与c,c++之间的交互接口。 JNIEXPORT jint JNI_OnLoad(JavaVM* vm, void* reserved); JNIEXPORT void JNI_OnUnload(JavaVM* vm, void* reserved);