使用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

 

posted on 2018-03-15 18:04  bwlcool  阅读(185)  评论(0编辑  收藏  举报

导航