使用jni遇到的诡异内存bug
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