当我开发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有错误导致打印出来吗?
答案 0 :(得分:1)
ex.printStackTrace()
帮助打印Throwable对象ex
的类和消息(如果有)以及跟踪信息。请参阅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);
}
}
答案 1 :(得分:0)
答案 2 :(得分:0)
您是否尝试过getMesssage或getLocalizedMessage?
http://docs.oracle.com/javase/6/docs/api/java/lang/Throwable.html#getMessage()
答案 3 :(得分:0)
第一行是从这里得到的:
public String toString() {
String s = getClass().getName();
String message = getLocalizedMessage();
return (message != null) ? (s + ": " + message) : s;
}
因此,如果您想添加第一行使用:
errorString += ex.toString + "<br/>";
StackTraceElement[] elements = ex.getStackTrace();
for (StackTraceElement element : elements) { // **code line 2**
errorString = errorString + "<br/>" + element.toString();
}