我有一个绑定到游标的ListActivity,当选择ListView中的项目时,startActivityForResult会启动EditItem活动,此EditItem活动会执行多个查询,每个查询都放在各自独立的Cursor中.这些用于填充微调器,非常类似于Access DB中的查找字段.
我的问题是,一旦用户离开此EditItem活动,通过提交,取消或返回按钮,返回到ListView活动并选择ListView中的另一个条目(相同的项目或不同的项目)我在sqliteCursor类中得到IllegalStateException错误(Android的,不是我的).我在两个活动的onDestroy方法中关闭我的游标,因为有时调用结果仍然会破坏调用活动.
这并不总是出现在第二个项目选择上,有时它会出现在第三个选择上.我想也许我的速度比操作系统快,所以我开始暂停,最多30秒,在我的动作之间,只有在第二次或第三次调用活动结果后才会抛出错误.没有多少暂停修复此问题.
编辑:错误是在调用super.finalize()时的sqliteCursor finalize方法中;
编辑#2:线程的堆栈跟踪:
Daemon System Thread [<5> HeapWorker] (Suspended (exception IllegalStateException)) sqliteCursor.finalize() line: 603 NativeStart.run() line: not available [native method]
编辑#3 LogCat的堆栈跟踪(partslist是表名):
INFO/dalvikvm(599): Ljava/lang/IllegalStateException;: Finalizing cursor android.database.sqlite.sqliteCursor@437541a0 on partslist that has not been deactivated or closed INFO/dalvikvm(599): at android.database.sqlite.sqliteCursor.finalize(sqliteCursor.java:596) INFO/dalvikvm(599): at dalvik.system.NativeStart.run(Native Method)
解决方法
完成后确保你使用cursor.close().