前言:在做项目的过程中,由于需要频繁的对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);