androidNDK开发中c与C++的细小区别
2016-12-06 17:26
501 查看
#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; }
相关文章推荐
- C++开发中内存分配及堆和栈的区别
- Android NDK Jni 开发C和C++的区别
- iOS开发介绍篇——C\C++的区别
- 【VS开发】【C/C++开发】memcpy和memmove的区别
- C/C++开发--#pragma pack(n)和__attribute__((aligned(m)))的区别
- c++和java在桌面应用软件开发的区别
- NDK开发 从入门到放弃(四:JNI函数、C与C++调用函数的区别)
- 【C/C++开发】__stdcall,__cdecl,__fastcall的区别
- 【C/C++开发】emplace_back() 和 push_back 的区别
- 系列:iOS开发-OC、C++以及C之间的区别
- 开始学习C++——第一篇 语言、编译器和开发环境的区别(摘自kriswj 百度)
- 【C/C++开发】循环中使用递减计数与递增计数的效率区别
- C++开发面试题:1.指针函数与函数指针的区别
- C++、C语言和JAVA开发的区别
- C++开发面试题:2.指针常量与常量指针的区别
- 【C/C++开发】malloc,calloc和realloc的区别和注意事项
- C/C++在ndk开发中的区别
- NDK开发之c、c++区别
- C++开发面试题:sizeof与strlen区别
- 【VS开发】【C++开发】const在函数前与函数后的区别