Android: определение причины перезапуска моего приложения после отмены обнаружения Bluetooth () - PullRequest
1 голос
/ 11 февраля 2012

Мое приложение перезапускается вскоре после того, как я позвоню BluetoothAdapter#cancelDiscovery().Другими словами, вызывается метод onCreate моего подкласса Application.Устройство использует Android версии 2.1.

Мне трудно определить, что именно вызывает перезапуск приложения.

Есть ли какие-либо приемы, помогающие отследить причину такой проблемы?

Большое спасибо за ваше время.

ОБНОВЛЕНИЕ

Перезапуск происходит, когда я прерываю попытку BluetoothSocket#connect() для адреса устройства, ранее сохраненного, но в настоящее время недоступного;это прерывание вызвано уничтожением родительского Activity, когда я нажимаю физическую кнопку Menu для перехода в пользовательское меню.

Logcat показывает, что поток, который я запускаю, заканчивается как часть моего цикла связинастроить.A Handler получает сообщение в этот момент;оно должно было бы получить сообщение, но затем приложение перезапускается, и handleMessage(msg) не вызывается.

Обработчик получил сообщения до того, как это событие произошло, и я знаю, что ссылка все еще существует, не является нулевой,Я не думаю, что это источник проблемы.

Вот мой манифест:

AndroidManifest.xml

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.ndb.mindpad" android:versionCode="1" android:versionName="8.4">
    <application android:name=".MindPad" android:icon="@drawable/icon" android:label="@string/app_name">
        <activity android:name=".Main"
            android:label="@string/app_name"
            android:theme="@android:style/Theme.Black.NoTitleBar.Fullscreen"
            android:configChanges="orientation">
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />
                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
        <activity android:name=".Preferences"
        android:label="@string/preferences_label"
        android:theme="@android:style/Theme.Black.NoTitleBar.Fullscreen"
        android:configChanges="orientation">
        </activity>
        <activity android:name="DeviceList"
            android:label="@string/communicator_label"
            android:configChanges="orientation">
        </activity>
        <service android:name="BluetoothService" />
        <service android:name="RecognizerService" />
    </application>
    <uses-permission android:name="android.permission.BLUETOOTH" />
    <uses-permission android:name="android.permission.BLUETOOTH_ADMIN" />
    <uses-permission android:name="android.permission.GET_TASKS"/>
    <uses-permission android:name="android.permission.VIBRATE" />
    <uses-permission android:name="android.permission.WAKE_LOCK" /> 
    <!-- Min Android SDK 2.1 -->
    <uses-sdk android:minSdkVersion="7" /> 
</manifest>

ОБНОВЛЕНИЕ 2

Я сделал так, как предложено в двух верхних найденных ответах здесь , и данные об исключениях не печатаются локально (CustomExceptionHandler ответ, измененный с * 1041)*) или сообщается в форме Google (ACRA ответ).Таким образом, это говорит о том, что нет необработанных исключений, поскольку я добавил механизмы вывода в каждый из моих конструкторов потоков.

Так почему же мое приложение будет воссоздано, если нет необработанных исключений?

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...