我有一个绑定到游标的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)
答案 0 :(得分:16)
完成后请确保cursor.close()
。
答案 1 :(得分:1)
添加缺失的cursor.close()
是该问题的解决方案。