Wie bekomme ich die Nummer der Zeile, wo die exception geworfen wurde mithilfe von Thread.UncaughtExceptionHandler?
Wenn ich einen try-catch-block zum abfangen einer Ausnahme, ich kann die Nummer der Zeile, wo die exception geworfen wurde, durch den Aufruf e.getStackTrace()
.
Wie diese:
java.lang.NumberFormatException: Invalid int: "abc"
java.lang.Integer.invalidInt(Integer.java:138)
java.lang.Integer.parse(Integer.java:375)
java.lang.Integer.parseInt(Integer.java:366)
java.lang.Integer.parseInt(Integer.java:332)
com.example.getarea.MainActivity.onCreate(MainActivity.java:42)
android.app.Activity.performCreate(Activity.java:5066)
android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1102)
android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2288)
android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2368)
android.app.ActivityThread.access$600(ActivityThread.java:151)
android.app.ActivityThread$H.handleMessage(ActivityThread.java:1330)
android.os.Handler.dispatchMessage(Handler.java:99)
android.os.Looper.loop(Looper.java:155)
android.app.ActivityThread.main(ActivityThread.java:5536)
java.lang.reflect.Method.invokeNative(Native Method)
java.lang.reflect.Method.invoke(Method.java:511)
com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1074)
com.android.internal.os.ZygoteInit.main(ZygoteInit.java:841)
dalvik.system.NativeStart.main(Native Method)
Aber wenn ich Thread.UncaughtExceptionHandler, ruft e.getStackTrace()
mir dieses:
java.lang.RuntimeException: Unable to start activity ComponentInfo{com.example.getarea/com.example.getarea.MainActivity}: java.lang.NumberFormatException: Invalid int: "abc"
android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2332)
android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2368)
android.app.ActivityThread.access$600(ActivityThread.java:151)
android.app.ActivityThread$H.handleMessage(ActivityThread.java:1330)
android.os.Handler.dispatchMessage(Handler.java:99)
android.os.Looper.loop(Looper.java:155)
android.app.ActivityThread.main(ActivityThread.java:5536)
java.lang.reflect.Method.invokeNative(Native Method)
java.lang.reflect.Method.invoke(Method.java:511)
com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1074)
com.android.internal.os.ZygoteInit.main(ZygoteInit.java:841)
dalvik.system.NativeStart.main(Native Method)
Wie bekomme ich die Nummer der Zeile, wo die exception geworfen wurde mithilfe von Thread.UncaughtExceptionHandler?
InformationsquelleAutor | 2014-05-28
Du musst angemeldet sein, um einen Kommentar abzugeben.
Versuchen
Das erste element in dem stack-trace ist die zuletzt genannte Methode (die oben auf dem Aufruf-stack).
Gibt es auch Methoden, um die Klasse, die Methode und die Datei name.
Wenn die
e
erhalten Sie in der UncaughtExceptionHandler funktioniert nicht gut für Sie (weil es umschließt die echte Ausnahme), können Sie versuchene.getCause()
und schauen Sie, dass stack-trace.meine app stürzt ab, wenn ich e.getStackTrace()[0].getLineNumber() oder e.getCause().getStackTrace()[0].getLineNumber(), keine Ahnung warum?
InformationsquelleAutor Thilo
Inspiriert durch Thilo und 范植勝 hier die copy 'n paste version für die faulen Leute:
Hinweis: Log.ee ist ein custom file writer
InformationsquelleAutor Martin Pfeffer