这两天写程序,碰到JNI错误,具体的错误如下:
JNI ERROR(app bug):accessed stale local reference 0x1d300009 (index 2 in a table of size 0)
VM aborting
Fatal singal 6 (SIGABRT) at 0x000028b3 (code=-6),thread 10501 (Thread -7129)
折腾了一天,在网上找了一些资料,弄明白原因,现在跟大家一起分享一下。
早前的Android版本,虽然用的是直接指针,但是GC(garbage collector 垃圾回收器,下面简称GC)不会随便回收对象,其实这样的做法是不安全的。但是从Android 4.0+开始,修改了GC。GC现在的工作模式是:全局对象使用过程中可能会被回收。不同于之前的使用直接指针,现在是通过一个 handle (指针的引用)去操作。当 GC 回收对象时,只需要修改这张 handle 表即可,而表的维护工作显然交给底层就好了。
出现这个问题怎么解决呢?有连个方法去解决: