在JNI编程中避免内存泄漏

总结

本文阐述了 JNI 编程可能引发的内存泄漏,JNI 编程既可能引发 Java Heap 的内存泄漏,也可能引发 nativememory 的内存泄漏,严重的情况可能使 JVM 运行异常终止。JNI软件开发人员在编程中,应当考虑以下几点,避免内存泄漏:

  • native code 本身的内存管理机制依然要遵循。
  • 使用 Global reference 时,当 native code 不再需要访问 Global reference时,应当调用 JNI 函数 DeleteGlobalRef() 删除 Global reference 和它引用的 Java对象。Global reference 管理不当会导致 Java Heap 的内存泄漏。
  • 透彻理解 Local reference,区分 Local reference 和 native code的局部变量,避免混淆两者所引起的 native memory 的内存泄漏。
  • 使用 Local reference 时,如果 Local reference 引用了大的 Java 对象,当不再需要访问Local reference 时,应当调用 JNI 函数 DeleteLocalRef() 删除 Localreference,从而也断开对 Java 对象的引用。这样可以避免 Java Heap 的 out of memory。
  • 使用 Local reference 时,如果在 native method 执行期间会创建大量的 Localreference,当不再需要访问 Local reference 时,应当调用 JNI 函数 DeleteLocalRef() 删除Local reference。Local reference 表空间有限,这样可以避免 Local reference表的内存溢出,避免 native memory 的 out of memory。
  • 严格遵循 Java JNI 规范书中的使用规则。

原文:http://www.ibm.com/developerworks/cn/java/j-lo-jnileak/

你可能感兴趣的:(Java)