java中提供了Thread.currentThread().getStackTrace()和new Throwable().getStackTrace()来获取堆栈信息,通过该方法返回堆栈数组。其数组第一个元素为Thread执行元素,索执行的方法为getStackTrace。其后依次是嵌套包裹执行的最里层,依次向外。
下面通过实例说明:
public static void display(){
StackTraceElement[] stes = Thread.currentThread().getStackTrace();
for (int i = 0; i < stes.length; i ++) {
System.out.println(i + "<------>" + stes[i].getClassName() + "<------>" + stes[i].getMethodName() + "<------>" + stes[i].getFileName());
}
}
public static void main(String[] args) {
display();
}
执行结果如下:
0<------>java.lang.Thread<------>getStackTrace<------>Thread.java
1<------>com.avcon.web.controller.LoginController<------>display<------>LoginController.java
2<------>com.avcon.web.controller.LoginController<------>main<------>LoginController.java
版权声明:本文为A123638原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。