[url]http://www.cnblogs.com/mengdd/p/3285592.html[/url]
缘起
今天看到有一个工具类中有一句:
输出的结果很简单,就是调用时的方法名。
文档:
其中使用的Thread类的第一个方法:
返回当前线程对象。
第二个方法:(阅读Java SE的文档:)
返回一个堆栈轨迹元素的数组,代表了这个线程的堆栈情况。
[color=red]如果:1.这个线程没有被开启;2.这个线程被开启了但是没有被系统运行过(因为线程运行是需要根据一定规律轮换的);3.这个线程结束了。[/color]
这三种情况下getStackTrace()返回的数组长度为0。
[color=red] 如果返回的数组长度不为0,那么数组的第一个元素代表栈顶元素,即是这个调用序列中最recent的方法。
第二个元素就是调用方法的类.
数组的最后一个元素代表栈底元素,即调用序列中最远的一个元素。[/color]
缘起
今天看到有一个工具类中有一句:
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]
本文介绍了如何使用Java Thread类的currentThread()方法与getStackTrace()方法组合来获取当前线程调用序列中最recent的方法名,即当前正在执行的方法名称。此方法常用于日志记录及调试中。
1422

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



