Я пытаюсь создать простой обработчик исключений, который поможет мне отладить приложение. Прямо сейчас, когда у меня есть исключение, я вынужден соединиться с отладчиком 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 на средстве моделирования андроида и просто зарегистрировать неперехваченное исключение, кажется, однако, менее удобный - я должен буду переключать приложения только для наблюдения деталей исключения.
Спасибо!
Вы ничего не видите, потому что исключение произошло в вашем потоке пользовательского интерфейса и стек полностью развернут. Таким образом, больше нет Looper и нет поддержки, которая используется для отображения Toast. Если вы хотите отобразить информацию об исключении на экране, вам, скорее всего, потребуется запустить другое действие в другом процессе.
Также существует проблема с вашим UncaughtExceptionHandler. Вам действительно следует сохранить ссылку на старую и вызвать ее в конце uncaughtException
, это позволяет системе отображать кнопку принудительного закрытия.