Исключение SQLite при возобновлении активности Android - PullRequest
4 голосов
/ 27 января 2011

Мое приложение имеет иерархию действий, 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

Ответы [ 2 ]

7 голосов
/ 25 марта 2011

Я только что решил это исключение в своем приложении.Не уверен, что причина была та же, что и у вас ...

Операция A выполняла запрос JOIN для 2 таблиц в базе данных через таблицу мостов.Записи из этого объединения были помещены в ListView, и когда пользователь щелкает запись, мое приложение запускает действие B. Когда вы нажимаете кнопку «Назад» в действии B, возобновляя действие A, возникает это исключение.

Исправлениедолжен был явно закрыть курсор (cur.close ()) в Деятельности A, когда он закончил получение данных.До того, как я просто закрывал БД.

ЭТОГО НЕ произошло, если действие A выполняло базовый запрос без JOIN.Поэтому, когда вы объединяете несколько таблиц и возвращаетесь в курсоре, запрос, который система выполняет для этого открытого курсора, когда ваша задача возобновляет работу, генерирует это исключение.Вы должны явно закрыть курсор, чтобы резюме установило новый.Еще один фактор, который мог вызвать это, заключается в том, что мой доступ к БД в действии А происходит в отдельном рабочем потоке.

1 голос
/ 14 февраля 2011

Проблема оказалась проблемой параллелизма, связанной с открытыми соединениями с базой данных.Все еще не совсем уверен в первопричине, так как я всегда закрывал свои связи.Как бы то ни было, я создал одно соединение, которое используется всеми действиями, и проблема исчезла.

...