2

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 に出力するエラーの原因がある理由を教えていただけますか??

4

4 に答える 4

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);
    }
}
于 2012-02-09T13:26:48.567 に答える
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();
}
于 2012-02-09T13:56:09.157 に答える
0

getMesssage または getLocalizedMessage を試しましたか??

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

于 2012-02-09T13:29:11.800 に答える
0

getCause()が例外チェーンの先頭にあるnull場合に戻ります。throwableそれは原因なので、原因を持つことはできません。

例外チェーンについては、こちらを参照してください。

于 2012-02-09T13:25:22.647 に答える