java变量先改成c变量,然后才能调用才/c++代码,最后把c变量改成java变量。JNI移植关键的是变量的调用,注意,一般情况下变量是系统分配内存的。但是在平台移植过程中,变量是要自己申请空间的,如下所示用malloc()申请。
c++:
jchar因为在java中不存在,所以先借助中间量转成array,
unsigned char* szText = NULL;
jclass clsstring = (*env)->FindClass(env,"java/lang/String");
jstring strencode = (*env)->NewStringUTF(env,"UTF-8");
jmethodID mid = (*env)->GetMethodID(env,clsstring, "getBytes", "(Ljava/lang/String;)[B");
jbyteArray barr= (jbyteArray)(*env)->CallObjectMethod(env,strText,mid,strencode);
jsize alen = (*env)->GetArrayLength(env,barr);
jbyte* ba = (*env)->GetByteArrayElements(env,barr,JNI_FALSE);
if(alen > 0)
{
szText = (char*)malloc(alen+1); //new char[alen+1];
memcpy(szText,ba,alen);
szText[alen]=0;
}
(*env)->ReleaseByteArrayElements(env,barr,ba,0);
下面是char-〉jchar的代码
c++
jstring rtn=0;
jclass strClass = (*env)->FindClass(env,"java/lang/String");
jmethodID ctorID = (*env)->GetMethodID(env,strClass, "<init>", "([BLjava/lang/String;)V");
jbyteArray bytes = (*env)->NewByteArray(env,strlen(dest));
(*env)->SetByteArrayRegion(env,bytes, 0, (jsize)strlen(dest), (jbyte*)dest);
jstring encoding = (*env)->NewStringUTF(env,"UTF-8");
rtn= (jstring)(*env)->NewObject(env,strClass, ctorID, bytes, encoding)