jni返回到java层的字符串有时正确,有时错误。错误的字符串可能是任何一串字符,看起来很奇怪。
通过加日志,得知生成的jstring已经不正确了,所以怀疑生成jstring用的char*有问题,可能被释放了。
分析代码,里边用的char*是从string转来的,只要string没被释放,char*就没问题。
问题找到了,代码只持有了char*,没有持有string,string在获取char*之后就可以被释放了,string释放之后,char*的指向就错误了,所以生成的jstring就错误了。
问题代码如下:
MD5 iMD5;
iMD5.GenerateMD5((unsigned char *) finalMessage, strlen(finalMessage));
const char *result = iMD5.ToString().c_str();// 这里没有持有toString生成的string,string后面就释放了。
//生成java String
jstring ret = env->NewStringUTF(result);
return ret;
修改如下:
string tempStr = iMD5.ToString();// 继续持有string
const char *result = tempStr.c_str();
// 生成java String
jstring ret = env->NewStringUTF(result);
return ret