[url]http://www.cnblogs.com/mengdd/p/3285592.html[/url]
缘起
今天看到有一个工具类中有一句:
String msgToPrint = Thread.currentThread().getStackTrace()[3]
.getMethodName();
输出的结果很简单,就是调用时的方法名。
文档:
其中使用的Thread类的第一个方法:
public static Thread currentThread()
返回当前线程对象。
第二个方法:(阅读Java SE的文档:)
public StackTraceElement[] getStackTrace()
返回一个堆栈轨迹元素的数组,代表了这个线程的堆栈情况。
[color=red]如果:1.这个线程没有被开启;2.这个线程被开启了但是没有被系统运行过(因为线程运行是需要根据一定规律轮换的);3.这个线程结束了。[/color]
这三种情况下getStackTrace()返回的数组长度为0。
[color=red] 如果返回的数组长度不为0,那么数组的第一个元素代表栈顶元素,即是这个调用序列中最recent的方法。
第二个元素就是调用方法的类.
数组的最后一个元素代表栈底元素,即调用序列中最远的一个元素。[/color]