前言:在做项目的过程中,由于需要频繁的对jni中封装的接口进行调用,因此是否及时释放jni中使用的一些占用内存的变量就显得很重要,我封装的jni接口在Java应用层调用了10000次,通过在调用前后添加打印日志发现每次调用的时间逐渐增大,但项目要求,耗时越小越好,嗯,一般都是要求耗时要小。哎!刚开始还不知道是这儿的问题,只到把所有对耗时影响的因素都查看了一遍才发现是jni封装中jfloatArray使用过程中没有释放的原因。
如下图所示,使用了两次jfloatArray,但在返回的时候并没有进行释放,因此耗时从2500ms逐渐增加到8000ms,最后导致系统崩溃,崩溃提示的原因还各不相同。解决的方法也很简单,加两句代码就ok了:
env->ReleaseFloatArrayElements(jint_arr1, int_arr1, 0);
env->ReleaseFloatArrayElements(jint_arr2, int_arr2, 0);

本文介绍了一个JNI内存泄漏的实际案例,作者在项目中发现随着JNI接口被频繁调用,耗时逐渐增加并最终导致系统崩溃。经排查,问题源于jfloatArray未正确释放。通过添加释放代码,成功解决了耗时增加及崩溃问题。
2700

被折叠的 条评论
为什么被折叠?



