首頁 > Java > java教程 > 在Java 9中如何顯示目前執行緒的所有堆疊幀?

在Java 9中如何顯示目前執行緒的所有堆疊幀?

WBOY
發布: 2023-09-05 20:09:06
轉載
857 人瀏覽過

在Java 9中如何显示当前线程的所有堆栈帧?

Stack Walking API 可以提供靈活的機制來遍歷調用堆疊並提取信息,使我們能夠以惰性方式過濾和訪問幀。 StackWalker類別是 Stack Walking API 的入口點。堆疊追蹤表示某個時間點的呼叫堆疊,其中每個元素代表一個方法呼叫。它包含從線程啟動到生成的所有呼叫。

在下面的範例中,我們可以使用 StackWalker API 列印/顯示目前執行緒的所有堆疊幀。

範例
import java.lang.StackWalker.StackFrame;
import java.lang.reflect.Method;
import java.util.List;
import java.util.stream.Collectors;

public class StackWalkerTest {
   public static void main(String args[]) throws Exception {
      Method test1Method = Helper1.class.<strong>getDeclaredMethod</strong>("test1", (Class<!--?-->[])null);
      test1Method.invoke(null, (Object[]) null);
   }
}

<strong>// Helper1 class
</strong>class Helper1 {
   protected static void test1() {
      Helper2.test2();
   }
}

<strong>// Helper2 class</strong>
class Helper2 {
   protected static void test2() {
      <strong>List<StackFrame></strong> stack = <strong>StackWalker.getInstance().walk</strong>((s) -> s.<strong>collect</strong>(Collectors.toList()));
      for(<strong>StackFrame </strong>frame : stack) {
         System.out.println(frame.<strong>getClassName()</strong> + " " + frame.<strong>getLineNumber()</strong> + " " +    frame.<strong>getMethodName()</strong>);
      }
   }
}
登入後複製

輸出

<strong>Helper2 23 test2
Helper1 16 test1
StackWalkerTest 9 main</strong>
登入後複製

以上是在Java 9中如何顯示目前執行緒的所有堆疊幀?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:tutorialspoint.com
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板