码迷,mamicode.com
首页 > 其他好文 > 详细

使用jni遇到的诡异内存bug

时间:2018-03-15 19:27:35      阅读:155      评论:0      收藏:0      [点我收藏+]

标签:md5   col   margin   java   sage   style   日志   span   tostring   

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

 

使用jni遇到的诡异内存bug

标签:md5   col   margin   java   sage   style   日志   span   tostring   

原文地址:https://www.cnblogs.com/bwlcool/p/8575049.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!