android - 恢复 Android Activity 时出现 SQLite 异常

标签 android sqlite android-activity android-intent

我的应用程序有一个 Activity 层次结构,A -launches- B -launches- C

在第三个 Activity “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”(假设没有崩溃)。

Activity “B”确实使用了异常中显示的 SQL 查询,但是我不知道为什么当我点击“返回”时它会导致异常,因为它与 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

最佳答案

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

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

解决方法是在 Activity A 完成检索数据后显式关闭游标 (cur.close())。在我刚刚关闭数据库之前。

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

关于android - 恢复 Android Activity 时出现 SQLite 异常,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4820556/

相关文章:

android - Espresso - 如何在回收站 View 中查找特定项目(顺序是随机的)

java - Android Facebook 登录弹出对话框

java - 如何为 Android Wear 应用创建游戏循环

java - 运行时在 jar 中添加文件

android - 如何防止从头开始重新创建数据库

android - 如何在 Android Studio 中制作颜色数组

java - 在VideoView中播放 'unsupported'编解码器

android - sqlite中的SQL sqlite条件查询(Android版)

android - 在将文本共享到应用程序后*仅*显示 toast (无 UI)?

android - 如何在浏览器 Android 中点击 url 启动应用程序