JNI参数jobject和jclass

参数,它们有一个共同的特点,包含JNIEnv *――它是一个接口指针,用于定位函数表中的函数!

     在JNI规范中一般称  为   “Interface Pointer”。看到这儿好像和过程调用很类似了!是的,JNI

     的操作过程,就是面向过程的!后面的jobject是  一个指向该类的指针,类似与C语言中的this。这个

     第二个参数是变化的,当该方法为类的实例方法时该参数为jobject;当该方法为类方法(即静态方法)

     时该参数为jclass,指向该类的class

根据不同方法前缀生成的头文件比较如下:

1、static与非static的比较:

[cpp]  view plain copy print ?
  1. /* 
  2.  * Class:     com_nedu_jni_helloword_HeaderFile 
  3.  * Method:    doInt 
  4.  * Signature: (DD)I 
  5.  */  
  6. JNIEXPORT jint JNICALL Java_com_nedu_jni_helloword_HeaderFile_doInt__DD  
  7.   (JNIEnv *, <span style="background-color: rgb(255, 0, 0);">jobject</span>, jdouble, jdouble);  
  8.   
  9. /* 
  10.  * Class:     com_nedu_jni_helloword_HeaderFile 
  11.  * Method:    doInt 
  12.  * Signature: (DDD)I 
  13.  */  
  14. JNIEXPORT jint JNICALL Java_com_nedu_jni_helloword_HeaderFile_doInt__DDD  
  15.   (JNIEnv *, <span style="color:#000000;background-color: rgb(255, 0, 0);">jclass</span>, jdouble, jdouble, jdouble);  

第一个是非static方法,第二个是static方法,不同点如上红色标记。其中的不同将在以后提到。


2、 privatefriendlyprotected以及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);


你可能感兴趣的:(JNI参数jobject和jclass)