Android アプリケーションを開発するときに、CrashReport クラスを作成し、それを使用してサーバーにレポートを送信したいと考えています。
UncaughtExceptionHandler を実装した CrashHandler というクラスを作り、Activity で NullPoint エラーを発生させる例を意図的に作成します。このクラスは問題なく動作しますが、メソッド uncaughtException に少し問題があります:</p>
@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() を使用しようとすると、throwable ではなく null が返されます。
スロー可能なクラスのソースコードを表示しようとしました...しかし、注目されました
getCause が null であるのに、printStackTrace に出力するエラーの原因がある理由を教えていただけますか??