有两种回收本地资源(对象,文件描述符等)的策略。
在finalize()期间调用JNI方法,以释放资源。有人建议不要实施finalize,基本上,您不能真正确定是否释放了本地资源。对于诸如内存之类的资源,这可能不是问题,但是例如,如果您有一个文件需要在可预测的时间刷新,则finalize()可能不是一个好主意。
手动调用清除方法。如果您有一个时间点知道必须清除资源,这将很有用。当我拥有必须在JNI代码中卸载DLL之前必须重新分配的资源时,便使用了此方法。为了允许以后重新加载DLL,在尝试卸载DLL之前,我必须确保已真正释放对象。仅使用finalize(),就不会保证这一点。可以将其与(1)结合使用,以允许在finalize()期间或在手动调用的清理方法中分配资源。(您可能需要一个WeakReferences的规范映射来跟踪哪些对象需要调用其清理方法。)
推测 PhantomReference 也可以用来解决此问题,但是我不确定这种解决方案将如何工作。
实际上,我在JNI文档上与您意见不一致。我发现JNI规范在大多数重要问题上都格外清晰,即使有关管理本地和全局引用的部分可以做得更加详细。



