我最初使用一个函数将一个char *作为UTF-8字符串返回给java,但由于我不断收到错误,我编写了以下函数来返回char*
作为Java byte[]
,所以我可以尝试将数组转换为java端的String:
jbyteArray Java_com_vektor_amapper_util_InputDeviceManager_getDevNameBytes(JNIEnv* env, jobject thiz, jint index) {
if(pDevs[index].device_name == NULL) return NULL;
int n=0;
while(pDevs[index].device_name){
n++;
} if (n==0) return NULL;
jbyteArray arr = (*env)->NewByteArray(env, n);
(*env)->SetByteArrayRegion(env,arr,0,n, (jbyte*)pDevs[index].device_name);
return arr;
}
但是当我调用它时,我的应用程序崩溃了。我错过了什么吗?
更新:条件缺少++,这导致无限循环。但现在使用以下代码:
jbyteArray Java_com_vektor_amapper_util_InputDeviceManager_getDevNameBytes(JNIEnv* env, jobject thiz, jint index) {
int n=0;
if(pDevs[index].device_name == NULL) return NULL;
while(pDevs[index].device_name++){
n++;
} if(n==0) return NULL;
jbyteArray arr = (*env)->NewByteArray(env, n);
(*env)->SetByteArrayRegion(env,arr,0,n, (jbyte*)pDevs[index].device_name);
return arr;
}
我得到了这个奇怪的JNI警告:
06-15 22:40:02.303:W / dalvikvm(7616):JNI警告:负jsize(NewByteArray)
怎么可能因为我只增加n
的价值?
更新2:以下代码有效:
jbyteArray Java_com_vektor_amapper_util_InputDeviceManager_getDevNameBytes(
JNIEnv* env, jobject thiz, jint index) {
if(pDevs[index].device_name == NULL) return NULL;
int n=0;
char* p = pDevs[index].device_name;
while(*p++){
n++;
} if(n<=0) return NULL;
jbyteArray arr = (*env)->NewByteArray(env, n);
(*env)->SetByteArrayRegion(env,arr,0,n, (jbyte*)pDevs[index].device_name);
return arr;
}
答案 0 :(得分:9)
不应该这样吗?
char* p = pDevs[index].device_name;
while( *p++) {
...
}