【问题标题】:SQLite Exception on Resuming Android Activity恢复 Android 活动的 SQLite 异常
【发布时间】:2011-01-27 18:55:47
【问题描述】:

我的应用有一个活动层次结构,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()

它会很好地调出电话拨号对话框。如果此时我按下后退按钮,我会得到“对不起!”弹出说我的应用程序意外停止。点击“强制关闭”按钮后,我的应用会恢复为 Activity 'B' 而不是预期的 'C'(假设没有崩溃)。

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

在活动“B”中,数据库在执行查询之前立即打开并在之后关闭。整天都在为此苦苦挣扎,因此将不胜感激任何 cmets。

 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

【问题讨论】:

    标签: android sqlite android-activity android-intent


    【解决方案1】:

    我刚刚在我的应用程序中解决了这个异常。不知道是不是和你一样的原因……

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

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

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

    【讨论】:

    • 感谢您抽出宝贵时间发表评论。这比我的解释更有意义,并提供了更好的答案,所以我正在改变答案。干杯克雷格。
    【解决方案2】:

    问题原来是与打开的数据库连接有关的并发问题。仍然不完全确定根本原因,因为我总是关闭我的连接。 无论如何,我创建了一个在所有活动之间共享的单一连接,问题就消失了。

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 2016-05-05
      • 2015-01-29
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2015-01-31
      • 2014-11-17
      相关资源
      最近更新 更多