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

http://www.cnblogs.com/mengdd/p/3285592.html
缘起
  今天看到有一个工具类中有一句:

String msgToPrint = Thread.currentThread().getStackTrace()[3]
                    .getMethodName();

  输出的结果很简单,就是调用时的方法名。





文档:
  其中使用的Thread类的第一个方法:

public static Thread currentThread()

  返回当前线程对象。



  第二个方法:(阅读Java SE的文档:)

public StackTraceElement[] getStackTrace()

  返回一个堆栈轨迹元素的数组,代表了这个线程的堆栈情况。

   如果:1.这个线程没有被开启;2.这个线程被开启了但是没有被系统运行过(因为线程运行是需要根据一定规律轮换的);3.这个线程结束了。

  这三种情况下getStackTrace()返回的数组长度为0。



  如果返回的数组长度不为0,那么数组的第一个元素代表栈顶元素,即是这个调用序列中最recent的方法。
    第二个元素就是调用方法的类.
  数组的最后一个元素代表栈底元素,即调用序列中最远的一个元素。

猜你喜欢

转载自panyongzheng.iteye.com/blog/2245695
今日推荐