关于恢复Android活动的SQLite异常

时间:2011-01-27 18:55:47

标签: android sqlite android-activity android-intent

我的应用程序具有活动层次结构,A-launches-B -launches-C

在第三个活动'C'中,我有一个按钮。

在此按钮的onClickListener中,我按如下方式启动Intent:

Intent intent = new Intent(Intent.ACTION_DIAL);
intent.setData(Uri.parse(uri));
startActivity(intent);
//I don't call finish()

它会调出电话拨号对话框。如果我在此时按下后退按钮,我会收到“抱歉!” popup说我的应用程序意外停止了。在点击“强制关闭”按钮时,我的应用程序将恢复为活动'B'而不是预期的'C'(假设没有崩溃)。

活动'B'确实使用异常中显示的SQL查询但是当我点击'Back'时我不知道为什么它会导致异常,因为它与Activity'C'无关。我的数据库已关闭,我没有收到泄漏警告。

在活动'B'中,数据库在执行查询之前立即打开,之后关闭。一整天都在苦苦挣扎,所以会有任何意见。

 Uncaught handler: thread main exiting due to uncaught exception
 java.lang.IllegalStateException: mQuery SELECT islocal, packageid, Name, mapradius FROM categories WHERE islocal=? 1 
     at android.database.sqlite.SQLiteQuery.requery(SQLiteQuery.java:162)
     at android.database.sqlite.SQLiteCursor.requery(SQLiteCursor.java:536)
     at android.app.Activity.performRestart(Activity.java:3740)
     at android.app.ActivityThread.handleWindowVisibility(ActivityThread.java:3312)
     at android.app.ActivityThread.access$2600(ActivityThread.java:123)
     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1890)
     at android.os.Handler.dispatchMessage(Handler.java:99)
     at android.os.Looper.loop(Looper.java:123)
     at android.app.ActivityThread.main(ActivityThread.java:4370)
     at java.lang.reflect.Method.invokeNative(Native Method)
     at java.lang.reflect.Method.invoke(Method.java:521)
     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868)
     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626)
     at dalvik.system.NativeStart.main(Native Method)
 Caused by: android.database.sqlite.SQLiteMisuseException: library routine called out of sequence: handle 0x0
     at android.database.sqlite.SQLiteProgram.native_bind_string(Native Method)
     at android.database.sqlite.SQLiteProgram.bindString(SQLiteProgram.java:178)
     at android.database.sqlite.SQLiteQuery.requery(SQLiteQuery.java:153)
     ... 13 more
ERROR/SemcCheckin(17282): Get crash dump level : java.io.FileNotFoundException: /data/semc-checkin/crashdump

2 个答案:

答案 0 :(得分:7)

我刚在我的应用中解决了这个异常。不确定原因是否与你的原因相同......

活动A通过桥接表对数据库中的2个表执行查询JOIN。来自该连接的记录被放入ListView中,当用户点击记录时,我的应用程序将触发活动B.当您点击活动B上的后退按钮时,恢复活动A时会发生此异常。

修复是在完成检索数据时显式关闭活动A中的游标(cur.close())。在我关闭数据库之前。

如果活动A在没有JOIN的情况下执行基本查询,则不会发生此DID。因此,当您连接多个表并返回游标时,系统在您的任务恢复时对该打开游标执行的重新查询会产生此异常。您必须显式关闭游标,以便简历建立一个新的。可能导致这种情况的另一个因素是我在活动A中的数据库访问发生在一个单独的工作线程上。

答案 1 :(得分:1)

问题结果是与数据库的开放连接有关的并发问题。仍然不完全确定根本原因,因为我总是关闭我的联系。 无论如何,我创建了一个在所有活动中共享的单一连接,问题已经消失。