簡體   English   中英

當Handler啟動的Runnable引發異常時,包含來自原始線程的方法調用

[英]Include method calls from original thread when Runnable started by Handler throws exception

我正在調用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的信息的堆棧跟蹤。

您可以使用Thread.currentThread().getStackTrace()來了解當前線程的堆棧跟蹤元素。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM