首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >关于java Throwable

关于java Throwable
EN

Stack Overflow用户
提问于 2012-02-09 21:22:26
回答 4查看 2.2K关注 0票数 2

当我开发安卓应用程序时,我想创建一个CrashReport类,然后用它来向我的服务器发送报告。

我制作了一个名为CrashHandler的类,它实现了UncaughtExceptionHandler,并故意制作了一个在Activity中导致NullPoint错误的示例,这个类工作得很好,但有一点小问题……在方法uncaughtException中:

代码语言:javascript
复制
    @Override
    public void uncaughtException(Thread thread, Throwable ex) {
        ex.printStackTrace(); //**code line 1**

        ....//some other codes and variables

        StackTraceElement[] elements = ex.getStackTrace(); 
        for (StackTraceElement element : elements) {       // **code line 2**
            errorString = errorString + "<br/>" + element.toString();
    }
    }

代码行1将堆栈跟踪打印为:

代码语言:javascript
复制
java.lang.NullPointerException

my.app.ExceptionCaughtActivity$1.onClick(ExceptionCaughtActivity.java:25)
android.view.View.performClick(View.java:2486)
android.view.View$PerformClick.run(View.java:9130)
android.os.Handler.handleCallback(Handler.java:587)
android.os.Handler.dispatchMessage(Handler.java:92)
android.os.Looper.loop(Looper.java:130)
android.app.ActivityThread.main(ActivityThread.java:3703)
java.lang.reflect.Method.invokeNative(Native Method)
java.lang.reflect.Method.invoke(Method.java:507)
com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:841)
com.android.internal.os.ZygoteInit.main(ZygoteInit.java:599)
dalvik.system.NativeStart.main(Native Method)

但是代码行只显示:

代码语言:javascript
复制
my.app.ExceptionCaughtActivity$1.onClick(ExceptionCaughtActivity.java:25)
android.view.View.performClick(View.java:2486)
android.view.View$PerformClick.run(View.java:9130)
android.os.Handler.handleCallback(Handler.java:587)
android.os.Handler.dispatchMessage(Handler.java:92)
android.os.Looper.loop(Looper.java:130)
android.app.ActivityThread.main(ActivityThread.java:3703)
java.lang.reflect.Method.invokeNative(Native Method)
java.lang.reflect.Method.invoke(Method.java:507)
com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:841)
com.android.internal.os.ZygoteInit.main(ZygoteInit.java:599)
dalvik.system.NativeStart.main(Native Method)

您会注意到它没有显示:

代码语言:javascript
复制
"java.lang.NullPointerException"

我知道我没有调用getCause(),但是当尝试使用getCause()时,它返回一个null,而不是一个可抛出的;

我试图查看可抛出的class...but的源代码,但没有得到任何提示

你能告诉我为什么getCause是空的,但是printStackTrace有一个打印错误的原因吗??

EN

回答 4

Stack Overflow用户

发布于 2012-02-09 21:26:49

ex.printStackTrace()有助于打印Throwable object ex的类和消息(如果有的话)以及跟踪信息。参见Throwable.toString()

原始堆栈跟踪本身不包括此信息,但您可以从Throwable对象获取该信息,该对象可能有消息,也可能没有消息,也可能没有原因。它总是有一个类!;-)

下面是来自Throwable的源代码

代码语言:javascript
复制
public void printStackTrace(PrintStream s) {
    synchronized (s) {
        s.println(this);
        StackTraceElement[] trace = getOurStackTrace();
        for (int i=0; i < trace.length; i++)
            s.println("\tat " + trace[i]);

        Throwable ourCause = getCause();
        if (ourCause != null)
            ourCause.printStackTraceAsCause(s, trace);
    }
}
票数 1
EN

Stack Overflow用户

发布于 2012-02-09 21:25:23

如果throwable位于异常链的顶部,则getCause()返回null。它是原因,所以它不能有原因。

您可以阅读有关异常链接here的内容。

票数 0
EN

Stack Overflow用户

发布于 2012-02-09 21:29:12

你试过getMesssage或getLocalizedMessage吗??

http://docs.oracle.com/javase/6/docs/api/java/lang/Throwable.html#getMessage()

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/9211635

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档