编写android程序时,有时会用到native方法通过C层代码实现某些功能,但是,在编写C文件后会出现乱码的问题,
04-14 15:28:14.661: W/dalvikvm(7478): JNI WARNING: NewStringUTF input is not valid Modified UTF-8: illegal start byte 0xfe
出现这种问题解决方法如下:
#include <jni.h>
#include <string.h>
#include <stdio.h>
#define LOG_TAG "HelloWorld"
#include <com_example_testjni_MainActivity.h>
#include <android/log.h>
#define LOGI(fmt, args...) __android_log_print(ANDROID_LOG_INFO, LOG_TAG, fmt, ##args)
#define LOGD(fmt, args...) __android_log_print(ANDROID_LOG_DEBUG, LOG_TAG, fmt, ##args)
#define LOGE(fmt, args...) __android_log_print(ANDROID_LOG_ERROR, LOG_TAG, fmt, ##args)
/* Native interface, it will be call in java code */
JNIEXPORT jstring JNICALL Java_com_example_testjni_MainActivity_outputJNI(
JNIEnv *env, jobject obj, jstring inputStr) {
jsize size = (*env)->GetStringUTFLength(env, inputStr);
LOGD("str length : %d", size);
const char *str;
str = (*env)->GetStringUTFChars(env, inputStr, NULL);
if (str == NULL) { //不要忘记检测,否则分配内存失败会抛出异常
return NULL; /* OutOfMemoryError already thrown */
}
//先将GetStringUTFChars得到的UTF-8字符str赋值到result,
//再通过ReleaseStringUTFChars释放掉C层的内存
jstring result = (*env)->NewStringUTF(env, str);
LOGI("dufresne--->%s", (const char *)str);
(*env)->ReleaseStringUTFChars(env, inputStr, str);
/* We assume here that the user does not type more than * 127 characters */
LOGI("dufresne release --->%s", (const char *)str);
return result;
}
/* This function will be call when the library first be load.
* You can do some init in the libray. return which version jni it support.
*/
jint JNI_OnLoad(JavaVM* vm, void* reserved) {
void *venv;
LOGI("dufresne----->JNI_OnLoad!");
if ((*vm)->GetEnv(vm, (void**) &venv, JNI_VERSION_1_4) != JNI_OK) {
LOGE("dufresne--->ERROR: GetEnv failed");
return -1;
}
return JNI_VERSION_1_4;
}