恢复Android Activity时的SQLite异常

4

我的应用程序有一个活动层次结构,A -启动- B -启动- C

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

在此按钮的onClickListner中,我按以下方式启动意图:

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

它可以正常弹出电话拨号对话框。如果此时我点击返回按钮,就会弹出“抱歉!”弹窗,提示我的应用程序意外停止。点击“强制关闭”按钮后,我的应用程序会回到Activity'B'而不是预期的'C'(假设没有崩溃)。
Activity 'B'确实使用了异常中显示的SQL查询,但我不知道为什么在我点击'Back'时它会引发异常,因为它与Activity 'C'无关。我的数据库已经关闭,我也没有收到任何泄漏警告。
在Activity '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个回答

7

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

Activity A通过桥接表在数据库中执行JOIN查询2个表。将该连接的记录放入ListView,当用户单击记录时,我的应用程序会触发Activity B。当您在Activity B上按下返回按钮,恢复Activity A时,就会出现此异常。

修复方法是在Activity A中显式关闭游标(cur.close()),当完成检索数据时。之前我只关闭了DB。

如果Activity A执行没有JOIN的基本查询,则不会发生此情况。因此,当您加入多个表并在光标中返回时,系统在任务恢复时执行的重新查询会生成此异常。您必须显式关闭游标,以便恢复建立新游标。另一个可能导致此问题的因素是我的Activity A中的DB访问发生在单独的工作线程上。


感谢您抽出时间发表评论。这比我的解释更有意义,提供了一个更好的答案,所以我正在更改答案。祝好 Craig。 - androider

1
问题最终被确认是与数据库打开连接有关的并发问题。虽然我总是关闭我的连接,但仍不完全确定根本原因。 无论如何,我创建了一个单一的连接,该连接在所有活动之间共享,问题已经解决了。

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接