ホームページ >Java >&#&チュートリアル >Java 9で現在のスレッドのすべてのスタックフレームを表示するにはどうすればよいですか?

Java 9で現在のスレッドのすべてのスタックフレームを表示するにはどうすればよいですか?

WBOY
WBOY転載
2023-09-05 20:09:06859ブラウズ

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

スタック ウォーキング 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 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事はtutorialspoint.comで複製されています。侵害がある場合は、admin@php.cn までご連絡ください。