jni 如何把char*转换成jstring类型???

在jni 使用中,需要把一个char*类型的转成jstring类型,我用了如下方法:
jstring stoJstring(JNIEnv* env, const char* pat)
{
jclass strClass = env->FindClass("Ljava/lang/String;");
jmethodID ctorID = env->GetMethodID(strClass, "", "([BLjava/lang/String;)V");
jbyteArray bytes = env->NewByteArray(strlen(pat));
env->SetByteArrayRegion(bytes, 0, strlen(pat), (jbyte*)pat);
jstring encoding = env->NewStringUTF("utf-8");
return (jstring)env->NewObject(strClass, ctorID, bytes, encoding);
}
可是在调用到这个方法的时候,报错:
Caused by :
Ljava/lang/ClassNotFoundException;: Ljava.lang.String; in loader dalvik.system.PathClassLoader@43d0b768
不懂为什么,是不是需要什么头文件,或是工程中要导入什么包啊?
各位,帮忙看一下了啦...

这个建议你看看有关编码的资料,我只是有些经验而已。

通常在C/C++的char* 类型是当前系统环境的字符编码/字符集,中文简体是GB2312,台湾的是BIG5等等,在java里首先尝试 new String(byte[])这种方式,就是不指定编码格式/字符集的构造函数,java应该也会使用当前系统环境的编码/字符集(好像跟环境参数encoding什么的有关),如果不行的话,就要去确认C/C++里面的字符串到底是什么编码/字符集了,然后用new String(byte[],charset)指定字符集再转换。
JNI里一样调用String 的对应的构造函数就行了。
每个操作系统的API里也有专门用于字符转换的函数,不过用这个不通用。我只知道在WindowsAPI里,WideCharToMultiByte,MultiByteToWideChar这两个API可以对Unicode字符串和多字节字符串相互装换。

jclass strClass = env->FindClass("Ljava/lang/String;");
把那个大写的L和后面的分号去掉。大写的L是用在定义字段类型和方法签名上的。

另外,UTF8是字符串的编码格式,经过UTF8编码过的字符串,只有全部都是标准ascii字符(0-127)的字符串才会一样有效,否则不能这么用。
如果你能确保字符串里面没有中文(或其他语言)的字符,可以直接用env->NewStringUTF返回,否则,你应该用"","([B)V"那个构造函数(在java 里对应new String(byte[]))把本地语言转换成java String。