Использование глобальной обработки исключений с помощью «setUncaughtExceptionHandler» и «Toast» - PullRequest
11 голосов
/ 03 июля 2010

Я пытаюсь создать простой обработчик исключений, который поможет мне отладить приложение.Прямо сейчас, когда у меня возникает исключение, я вынужден соединиться с отладчиком 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();             
            }
        });

    }
}

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

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

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

Спасибо!

Ответы [ 3 ]

14 голосов
/ 05 июля 2011

Это возможно.Вам нужно сделать это внутри другого потока
Тогда это должно быть так

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

        @Override
        public void uncaughtException(Thread thread, Throwable ex) {
            new Thread() {
                @Override
                public void run() {
                    Looper.prepare();  
                    Toast.makeText(TicTacToe.this, "TOAST", toast.LENGTH_LONG).show();
                    Looper.loop();
                }
            }.start();
        }
    });
11 голосов
/ 03 июля 2010

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

Существует также проблема с вашим UncaughtExceptionHandler. Вы действительно должны сохранить ссылку на старую и вызвать ее в конце uncaughtException, что позволит системе отобразить кнопку Force Close.

1 голос
/ 28 мая 2016

Я знаю, что это старый вопрос, но я надеюсь, что смогу спасти кого-то от разочарования и потери времени.

Qberticus прав, вы не можете запустить Activity в том же процессе, но вы можете убить текущий процесс и запустить его в Android:

Intent intent = new Intent(myContext, AnotherActivity.class);
intent.putExtra("error", errorReport.toString());
myContext.startActivity(intent);

android.os.Process.killProcess(android.os.Process.myPid());
System.exit(10);

см. на этой странице , где приведен отличный пример работы:

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