#if defined(__cplusplus)//如果是C++语言 JNIEnv定义为JNIEnv 这么一个结构体
typedef _JNIEnv JNIEnv;
typedef _JavaVM JavaVM;
#else
typedef const struct JNINativeInterface* JNIEnv;//不是c++语言则 JNINativeInterface这么一个结构体
typedef const struct JNIInvokeInterface* JavaVM;
#endif
我们在生成头文件时候会生成2个对象
JNIEXPORT jint JNICALL Java_com_heima_jni02_provide_DataProvider_getPressure
(JNIEnv *, jobject);
如果java的native定义的方法中的签名有参数,那么参数则会跟在jobject后面,
看到JNIEnv 我们实质是取得了JNINativeInterface* JNIEnv指针的指针,然而JNIEnv里面存放结构体我们得使用**env获取结构体,从而
才能使用结构体里面的方法.
C和C++调用函数的方法中签名少一个将结构体实例传入
//c语言的实现
// return (*env)->NewStringUTF(env,"hello from c");
//c++实现
return (env)->NewStringUTF("hello in c");
首先是*env和env:
源码中C获取的是结构体的指针的指针,而C++获取的是结构体的指针,所以获取方法有*env和env的区别
typedef _JNIEnv JNIEnv;
typedef _JavaVM JavaVM;
#else
typedef const struct JNINativeInterface* JNIEnv;
typedef const struct JNIInvokeInterface* JavaVM;
#endif
扩展
//在c++代码中的 jstring转c char操作
char* Jstring2CStr(JNIEnv* env, jstring jstr)
{
char* rtn = NULL;
jclass clsstring = (env)->FindClass("java/lang/String");
jstring strencode = (env)->NewStringUTF("GB2312");
jmethodID mid = (env)->GetMethodID(clsstring, "getBytes", "(Ljava/lang/String;)[B");
jbyteArray barr= (jbyteArray)(env)->CallObjectMethod(jstr,mid,strencode); // String .getByte("GB2312");
jsize alen = (env)->GetArrayLength(barr);
jbyte* ba = (env)->GetByteArrayElements(barr,JNI_FALSE);
if(alen > 0)
{
rtn = (char*)malloc(alen+1); //"\0"
memcpy(rtn,ba,alen);
rtn[alen]=0;
}
(env)->ReleaseByteArrayElements(barr,ba,0); //
return rtn;
}
//在c代码中的 jstring转c char操作
//工具方法 : 把java中的string 转化成 c语言中 char数组
//返回值是 char数组的首地址
char* Jstring2CStr(JNIEnv* env, jstring jstr)
{
char* rtn = NULL;
jclass clsstring = (*env)->FindClass(env,"java/lang/String");
jstring strencode = (*env)->NewStringUTF(env,"GB2312");
jmethodID mid = (*env)->GetMethodID(env,clsstring, "getBytes", "(Ljava/lang/String;)[B");
jbyteArray barr= (jbyteArray)(*env)->CallObjectMethod(env,jstr,mid,strencode); // String .getByte("GB2312");
jsize alen = (*env)->GetArrayLength(env,barr);
jbyte* ba = (*env)->GetByteArrayElements(env,barr,JNI_FALSE);
if(alen > 0)
{
rtn = (char*)malloc(alen+1); //"\0"
memcpy(rtn,ba,alen);
rtn[alen]=0;
}
(*env)->ReleaseByteArrayElements(env,barr,ba,0); //释放空间
return rtn;
}