在SQLiteCursor for Android中防止IllegalStateException

时间:2011-02-05 15:06:09

标签: android sqlite cursor

我有一个绑定到游标的ListActivity,当选择了ListView中的项目EditItem startActivityForResult活动由EditItem启动时,此{{1} } activity会预先形成多个查询,每个查询都放在各自独立的Cursor中。这些用于填充微调器,非常类似于Access DB中的查找字段。

我的问题是,一旦用户离开此EditItem活动,通过提交,取消或返回按钮,返回ListView活动并选择ListView中的其他条目(相同的项目或不同的项目)我的IllegalStateException课程中出现SQLiteCursor错误(Android,而不是我的)。我两个活动的onDestroy方法中关闭我的游标,因为有时调用结果仍然会破坏调用活动。

这并不总是出现在第二个项目选择上,有时它会出现在第三个选择上。我想也许我的速度比操作系统快,所以我开始暂停,最多30秒,在我的动作之间,只有在第二次或第三次调用活动结果后才会抛出错误。没有多少暂停修复此问题。

修改:调用SQLiteCursor finalize

时,super.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)

2 个答案:

答案 0 :(得分:16)

完成后请确保cursor.close()

答案 1 :(得分:1)

添加缺失的cursor.close()是该问题的解决方案。