参考了文章:http://blog.csdn.net/ztp800201/article/details/7388189,http://blog.csdn.net/liaowenfeng/article/details/8668085
总结如下:
在jni中使用env是有两种情况的,c语言和c++语言。
C语言互相转换版本:
//将char类型转换成jstring类型
jstring CStr2Jstring( JNIEnv* env,const char* str )
{
jsize len = strlen(str);
// 定义java String类 strClass
jclass strClass = (*env)->FindClass(env, "java/lang/String");
//设置String, 保存语言类型,用于byte数组转换至String时的参数
jstring encoding = (*env)->NewStringUTF(env, "GB2312");
// 获取java String类方法String(byte[],String)的构造器,用于将本地byte[]数组转换为一个新String
jmethodID ctorID = (*env)->GetMethodID(env, strClass, "<init>", "([BLjava/lang/String;)V");
// 建立byte数组
jbyteArray bytes = (*env)->NewByteArray(env, len);
// 将char* 转换为byte数组
(*env)->SetByteArrayRegion(env, bytes, 0, len, (jbyte*)str);
//将byte数组转换为java String,并输出
return (jstring)(*env)->NewObject(env, strClass, ctorID, bytes, encoding);
}
//将jstring类型转换成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);
jsize alen = (*env)->GetArrayLength(env, barr);
jbyte * ba = (*env)->GetByteArrayElements(env, barr,JNI_FALSE);
if(alen > 0)
{
rtn = (char*)malloc(alen+1); //new char[alen+1];
memcpy(rtn,ba,alen);
rtn[alen]=0;
}
(*env)->ReleaseByteArrayElements(env, barr,ba,0);
return rtn;
}
C++版本如下:
//将char类型转换成jstring类型
jstring CStr2Jstring( JNIEnv* env, const char* pat )
{
// 定义java String类 strClass
jclass strClass = (env)->FindClass("Ljava/lang/String;");
// 获取java String类方法String(byte[],String)的构造器,用于将本地byte[]数组转换为一个新String
jmethodID ctorID = (env)->GetMethodID(strClass, "<init>", "([BLjava/lang/String;)V");
// 建立byte数组
jbyteArray bytes = (env)->NewByteArray((jsize)strlen(pat));
// 将char* 转换为byte数组
(env)->SetByteArrayRegion(bytes, 0, (jsize)strlen(pat), (jbyte*)pat);
//设置String, 保存语言类型,用于byte数组转换至String时的参数
jstring encoding = (env)->NewStringUTF("GB2312");
//将byte数组转换为java String,并输出
return (jstring)(env)->NewObject(strClass, ctorID, bytes, encoding);
}
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);
jsize alen = env->GetArrayLength(barr);
jbyte * ba = env->GetByteArrayElements(barr,JNI_FALSE);
if(alen > 0)
{
rtn = (char*)malloc(alen+1); //new char[alen+1];
memcpy(rtn,ba,alen);
rtn[alen]=0;
}
env->ReleaseByteArrayElements(barr,ba,0);
return rtn;
}
</pre><p></p><pre>
注意上面两种情况env的不同使用方法,具体的解释可参考jni..h头文件中的说明:
/*
* We use inlined functions for C++ so that programmers can write:
*
* env->FindClass("java/lang/String")
*
* in C++ rather than:
*
* (*env)->FindClass(env, "java/lang/String")
*
* in C.
*/
另外注意下面这句话的不同,主要指“”里的字符串,两个版本不同,我用的是C语言,刚开始是用网上下面的一个版本,运行总是崩掉,最后换成上面一个版本才OK。C++的版本有人如果遇到注意一下即可。
C语言版本:
jclass strClass = (*env)->FindClass(env, "java/lang/String");
C++版本:
jclass strClass = (env)->FindClass("Ljava/lang/String;");