package exception;
import java.util.Scanner;
public class StackTraceTest {
public static int factorial(int n) {
System.out.println("factorial(" + n + "):");
//打印出程序调用的信息
Throwable t = new Throwable();
StackTraceElement[] frames = t.getStackTrace();
for(StackTraceElement f : frames) {
System.out.println(f);
}
int r;
if(n <= 1) {
r = 1;
} else {
r = n * factorial(n - 1);
}
System.out.println("return " + r);
return r;
}
public static void main(String[] args) {
Scanner in = new Scanner(System.in);
System.out.println("Please input a number: ");
int n = in.nextInt();
factorial(n);
}
}
本文介绍了一个Java程序示例,该程序使用递归计算阶乘并打印出调用堆栈信息。通过创建Throwable实例获取堆栈跟踪,展示了如何在Java中观察递归调用的过程。
1万+

被折叠的 条评论
为什么被折叠?



