当Handler启动的Runnable抛出异常时,包括来自原始线程的方法调用

时间:2017-07-24 11:20:05

标签: java android exception-handling handler stack-trace

我正在调用post()方法:

void post() {
    new Handler().post(() -> {
        throw new RuntimeException("Something went wrong...");
    });
}

我正在获得堆栈跟踪:

java.lang.RuntimeException: Something went wrong...
                  at com.package.MyApp.lambda$post$0(MyApp.java:39)
                  at com.package.MyApp$$Lambda$1.run(Unknown Source)
                  at android.os.Handler.handleCallback(Handler.java:739)
                  at android.os.Handler.dispatchMessage(Handler.java:95)
                  at android.os.Looper.loop(Looper.java:148)
                  at android.app.ActivityThread.main(ActivityThread.java:5417)
                  at java.lang.reflect.Method.invoke(Native Method)
                  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:726)
                  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:616)

是否可以在堆栈跟踪中包含方法post()的调用方?

换句话说,我要说我正在呼叫foo(),呼叫bar(),最后拨打post()

void foo() { bar(); }
void bar() { post(); }

我要实现的目标是获取包含foobarpost信息的堆栈跟踪。

1 个答案:

答案 0 :(得分:0)

您可以使用Thread.currentThread().getStackTrace()来了解当前线程的堆栈跟踪元素。