Мое приложение имеет иерархию действий, A -launches- B -launches- C
В третьем занятии 'C' у меня есть кнопка.
В onClickListener этой кнопки я запускаю Намерение следующим образом:
Intent intent = new Intent(Intent.ACTION_DIAL);
intent.setData(Uri.parse(uri));
startActivity(intent);
//I don't call finish()
Это нормально вызывает диалог набора номера телефона. Если в этот момент я нажму кнопку «Назад», я получу «Извините!» всплывающее окно говорит, что мое приложение неожиданно остановилось. После нажатия кнопки «Принудительное закрытие» мое приложение возвращается к действию «B», а не к ожидаемому «C» (при условии отсутствия сбоев).
Действие «B» использует SQL-запрос, показанный в исключении, однако я не знаю, почему оно вызывает исключение, когда я нажимаю «Назад», поскольку оно не имеет ничего общего с действием «С». Моя база данных была закрыта, и я не получаю предупреждения об утечках.
В действии '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