Используя глобальную обработку исключений с “setUncaughtExceptionHandler” и “Тостом”

Я пытаюсь создать простой обработчик исключений, который поможет мне отладить приложение. Прямо сейчас, когда у меня есть исключение, я вынужден соединиться с отладчиком Eclipse просто для наблюдения деталей исключения.

Избегать, чтобы я использовал setUncaughtExceptionHandler, чтобы обработать любое необработанное исключение и отобразить Тост на исключении. К сожалению, это не работает.

public class TicTacToe extends Activity {
    /** Called when the activity is first created. */
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);

        Thread.currentThread().setUncaughtExceptionHandler(new UncaughtExceptionHandler() {

            @Override
            public void uncaughtException(Thread thread, Throwable ex) {
                Toast.makeText(TicTacToe.this, "TOAST", Toast.LENGTH_LONG).show();
            }
        });

        setContentView(R.layout.main);

        Button continueButton = (Button) findViewById(R.id.cell01);
        continueButton.setOnClickListener(new OnClickListener() {

            @Override
            public void onClick(View v) {

                int i = 5;
                i = 5 / 0;

                Toast.makeText(TicTacToe.this, "BUTTON", Toast.LENGTH_LONG).show();             
            }
        });

    }
}

По существу я сделал форму с единственной кнопкой, нажимающей, на котором, она выдаст devision нулем исключение. Однако нажатие кнопки не заставляет глобальный обработчик тостов показывать. Вместо этого кнопка остается оранжевой (нажатый), и ничего не происходит.

Само собой разумеется, если я комментирую меня = 5 / 0; я вижу тост, который говорит, что кнопка была нажата.

Два вопроса: 1) Почему тост не показывает в теле UncaughtExceptionHandler? Как действительно заставляют это показывать? 2) Существует ли альтернативный/лучше путь к глобальной обработке исключений? Я предполагаю, что мог установить aLogCat на средстве моделирования андроида и просто зарегистрировать неперехваченное исключение, кажется, однако, менее удобный - я должен буду переключать приложения только для наблюдения деталей исключения.

Спасибо!

11
задан Ryan Conrad 3 July 2010 в 13:23
поделиться

1 ответ

Вы ничего не видите, потому что исключение произошло в вашем потоке пользовательского интерфейса и стек полностью развернут. Таким образом, больше нет Looper и нет поддержки, которая используется для отображения Toast. Если вы хотите отобразить информацию об исключении на экране, вам, скорее всего, потребуется запустить другое действие в другом процессе.

Также существует проблема с вашим UncaughtExceptionHandler. Вам действительно следует сохранить ссылку на старую и вызвать ее в конце uncaughtException , это позволяет системе отображать кнопку принудительного закрытия.

11
ответ дан 3 December 2019 в 03:51
поделиться
Другие вопросы по тегам:

Похожие вопросы: