使用jni遇到的诡异内存bug

Posted bwlcool

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了使用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

 

以上是关于使用jni遇到的诡异内存bug的主要内容,如果未能解决你的问题,请参考以下文章

处理Activity#onResume()遇到java.lang.IllegalArgumentException诡异异常

处理Activity#onResume()遇到java.lang.IllegalArgumentException诡异异常

和各种诡异 Bug 打交道 13 年,我总结了 18 个经验

使用 PHPMailer 发送邮件出现诡异bug,间歇性发送失败

找出诡异的Bug:数据怎么存不进去

一个诡异的MySQL查询超时问题,居然隐藏着存在了两年的BUG