缘起:
今天看到有一个工具类中有一句:
String msgToPrint = Thread.currentThread().getStackTrace()[1].getMethodName();
输出的结果很简单,就是调用类的方法名。
文档:
public StackTraceElement[] getStackTrace()
-
返回一个表示该线程堆栈转储的堆栈跟踪元素数组。如果该线程尚未启动或已经终止,则该方法将返回一个零长度数组。如果返回的数组不是零长度的,则其第一个元素代表堆栈顶,它是该序列中最新的方法调用。最后一个元素代表堆栈底,是该序列中最旧的方法调用。
如果有安全管理器,并且该线程不是当前线程,则通过 RuntimePermission("getStackTrace") 权限调用安全管理器的 checkPermission 方法,查看是否可以获取堆栈跟踪。
某些虚拟机在某些情况下可能会从堆栈跟踪中省略一个或多个堆栈帧。在极端情况下,没有该线程堆栈跟踪信息的虚拟机可以从该方法返回一个零长度数组。
-
返回:
- StackTraceElement 数组,每个数组代表一个堆栈帧。
其中使用的Thread类的第一个方法: