您的当前位置:首页正文

获取当前线程状态 Thread.currentThread().getStackTrace()

2024-11-13 来源:个人技术集锦
[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]
显示全文