在SQLiteCursor for Android中防止IllegalStateException

前端之家收集整理的这篇文章主要介绍了在SQLiteCursor for Android中防止IllegalStateException前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我有一个绑定到游标的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().

猜你在找的Android相关文章