Java: 获取当前执行位置的文件名/类名/方法名/行号

时间:2022-01-29 19:31:01

在 JAVA 程序有时需要获取当前代码位置, 于是就利用 Thread.currentThread().getStackTrace() 写了下面这个工具类, 用来获取当前执行位置处代码的文件名/类名/方法名/行号.

当然通过 new Throwable().getStackTrace() 也能得到同样信息, 在处理异常时用这种方法还行, 否则需要 new 一个 Throwable, 感觉有点浪费​????​

至于为什么 CurrentLineInfo.originStackIndex 的值是 2 呢? 这是因为通过自定义的静态方法调用 Thread.currentThread().getStackTrace() 获取当前函数栈时, 已多加了两层方法调用.

比如说在 Main.main() 方法中获取当前行号时, 其调用链为:

Main.main() --> CurrentLineInfo.getLineNumber() --> Thread.getStackStrace()

因为栈是 先入后出 (队列是 先入先出), 所以最初调用位置的函数栈下表是 2.

这一点在调试时也可以看到:

Java: 获取当前执行位置的文件名/类名/方法名/行号

下面是源码和测试:

CurrentLineInfo.java:

package com.example.lineno;

public class CurrentLineInfo {
    private static int originStackIndex = 2;

    public static String getFileName() {
        return Thread.currentThread().getStackTrace()[originStackIndex].getFileName();
    }

    public static String getClassName() {
        return Thread.currentThread().getStackTrace()[originStackIndex].getClassName();
    }

    public static String getMethodName() {
        return Thread.currentThread().getStackTrace()[originStackIndex].getMethodName();
    }

    public static int getLineNumber() {
        return Thread.currentThread().getStackTrace()[originStackIndex].getLineNumber();
    }
}

测试代码 Main.java:

package com.example.lineno;

public class Main {
    public static void main(String[] args) {
        System.out.println(CurrentLineInfo.getFileName());
        System.out.println(CurrentLineInfo.getClassName());
        System.out.println(CurrentLineInfo.getMethodName());
        System.out.println(CurrentLineInfo.getLineNumber());
    }
}

测试输出:

FileName: Main.java
ClassName: com.example.lineno.Main
MethodName: main
LineNumber: 8