java 中可以通過 eclipse 等工具直接打印堆棧,但是對于某些環(huán)境中無法使用 eclipse 工具時,需要知道堆棧,如何處理呢?
介紹3種方法供選擇:
方法一:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
package name.xu; public class CallStack { public static void printCallStatck() { Throwable ex = new Throwable(); StackTraceElement[] stackElements = ex.getStackTrace(); if (stackElements != null ) { for ( int i = 0 ; i < stackElements.length; i++) { System.out.print(stackElements[i].getClassName()+ "/t" ); System.out.print(stackElements[i].getFileName()+ "/t" ); System.out.print(stackElements[i].getLineNumber()+ "/t" ); System.out.println(stackElements[i].getMethodName()); System.out.println( "-----------------------------------" ); } } } } |
方法二:
1
2
|
Exception e = new Exception( "this is a log" ); e.printStackTrace(); |
方法三:
String fullStackTrace = org.apache.commons.lang.exception.ExceptionUtils.getFullStackTrace(e)
方法四:
1
|
Thread.currentThread().getStackTrace() |
個人推薦,方法一,原因:簡單易用,速度快
參考資料:
1、http://blog.csdn.net/chief1985/article/details/4618492
2、http://www.cnblogs.com/flyme/archive/2012/04/10/2440029.html
3、http://stackoverflow.com/questions/1069066/get-current-stack-trace-in-java【推薦仔細看看】
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持服務(wù)器之家。