gpt4 book ai didi

java - 关于java Throwable

转载 作者:行者123 更新时间:2023-11-30 11:47:40 28 4
gpt4 key购买 nike

当我开发 android 应用程序时,我想制作一个 CrashReport 类,然后使用它向我的服务器发送报告。

我做了一个名为CrashHandler的类,它实现了UncaughtExceptionHandler,并做了一个例子,故意在Activity中导致一个NullPoint错误,这个类运行良好,但有点问题......在方法uncaughtException:

    @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 将堆栈跟踪打印为:

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)

但代码行只显示:

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)

你注意到它没有显示:

"java.lang.NullPointerException"

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

我试图查看 throwable 类的源代码...但注意到了

你能告诉我为什么 getCause 为 null 但 printStackTrace 打印出错误原因吗??

最佳答案

ex.printStackTrace() 有助于打印 Throwable 对象 exclassmessage(如果有的话) > 以及跟踪信息。请参阅 Throwable.toString()

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

这是来自 Throwable 的源代码:

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);
}
}

关于java - 关于java Throwable,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9211635/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com