我的应用程序具有活动层次结构,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
答案 0 :(得分:7)
我刚在我的应用中解决了这个异常。不确定原因是否与你的原因相同......
活动A通过桥接表对数据库中的2个表执行查询JOIN。来自该连接的记录被放入ListView中,当用户点击记录时,我的应用程序将触发活动B.当您点击活动B上的后退按钮时,恢复活动A时会发生此异常。
修复是在完成检索数据时显式关闭活动A中的游标(cur.close())。在我关闭数据库之前。
如果活动A在没有JOIN的情况下执行基本查询,则不会发生此DID。因此,当您连接多个表并返回游标时,系统在您的任务恢复时对该打开游标执行的重新查询会产生此异常。您必须显式关闭游标,以便简历建立一个新的。可能导致这种情况的另一个因素是我在活动A中的数据库访问发生在一个单独的工作线程上。
答案 1 :(得分:1)
问题结果是与数据库的开放连接有关的并发问题。仍然不完全确定根本原因,因为我总是关闭我的联系。 无论如何,我创建了一个在所有活动中共享的单一连接,问题已经消失。