81

如果我的应用程序崩溃,它会挂起几秒钟,然后 Android 会告诉我应用程序崩溃并需要关闭。所以我想用一个通用的方法来捕捉我的应用程序中的所有异常:

try {
    // ... 
} catch(Exception e) { 
    // ...
} 

并创建一个新Activity的解释应用程序立即崩溃(并且还让用户有机会发送包含错误详细信息的邮件),而不是由于 Android 而出现延迟。有没有更好的方法来实现这一点,还是不鼓励这样做?

更新:我正在使用启用了 ART 的 Nexus 5,但我没有注意到我曾经在应用程序崩溃时遇到的延迟(我最初所说的“挂起”)。我认为由于现在一切都是本机代码,因此崩溃会立即发生,同时获取所有崩溃信息。也许 Nexus 5 很快 :) 无论如何,这在未来的 Android 版本中可能不会令人担心(鉴于 ART 将成为 Android L 中的默认运行时)。

4

3 回答 3

105

在这里,检查链接以供参考

在这里你创建一个类说ExceptionHandlerimplements java.lang.Thread.UncaughtExceptionHandler..

在本课程中,您将做一些拯救生命的事情,例如创建堆栈跟踪和准备上传错误报告等......

现在是重要的部分,即如何捕获该异常。虽然很简单。在覆盖方法中调用 super 方法之后,在每个 Activity 中复制以下代码行onCreate

Thread.setDefaultUncaughtExceptionHandler(new ExceptionHandler(this));

您的 Activity 可能看起来像这样……</p>

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

        Thread.setDefaultUncaughtExceptionHandler(new ExceptionHandler(this));

        setContentView(R.layout.main);
    }
}

希望这可以帮助...

于 2013-05-15T10:34:46.203 回答
9

您可以只使用通用警报对话框来快速显示错误消息。例如...

//******************************************
//some generic method
//******************************************
private void doStuff()
{       
    try
    {
        //do some stuff here
    }
    catch(Exception e)
    {
        messageBox("doStuff", e.getMessage());
    }
}


//*********************************************************
//generic dialog, takes in the method name and error message
//*********************************************************
private void messageBox(String method, String message)
{
    Log.d("EXCEPTION: " + method,  message);

    AlertDialog.Builder messageBox = new AlertDialog.Builder(this);
    messageBox.setTitle(method);
    messageBox.setMessage(message);
    messageBox.setCancelable(false);
    messageBox.setNeutralButton("OK", null);
    messageBox.show();
}

您还可以在此方法中添加其他错误处理选项,例如 print stacktrace

于 2013-08-09T09:40:46.523 回答
4

我在 Log 类中找到了“wtf”(多么可怕的失败)方法。从描述:

根据系统配置,可能会向 DropBoxManager 添加报告和/或可能会立即终止进程并显示错误对话框。

http://developer.android.com/reference/android/util/Log.html

于 2014-03-16T15:19:55.483 回答