gpt4 book ai didi

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

转载 作者:IT王子 更新时间:2023-10-29 06:32:05 26 4
gpt4 key购买 nike

我的应用程序有一个 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/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com