[Java]取得当前代码所在函数的函数名

要取得当前运行代码的函数名,可以用:

Thread.currentThread().getStackTrace()[1].getMethodName();

但是,这行代码有些过长,嵌入业务代码稍显突兀,这时可以采用下面的共通函数:

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

从上面代码可以看出,其本质是取当前线程的调用栈,栈的第一个元素是getStackTrace自己,第二个是digoutMethodName,第三个就是调用digoutMethodName的外界函数了。如果调用层次越深,调用栈越长,最终会到main函数处。

以下为完整程序:

复制代码
package com.ufo.func;

public class Tester {
    public static void main(String[] args) {
        foo();
        bar();
    }
    
    public static void foo() {
        System.out.println(Thread.currentThread().getStackTrace()[1].getMethodName());
    }
    
    private static int bar() {
        System.out.println(digoutMethodName());
        System.out.println("----------------------");
        printStackMethods();
        return 0;
    }
    
    public static String digoutMethodName() {
        return Thread.currentThread().getStackTrace()[2].getMethodName();
    }
    
    private static void printStackMethods() {
        for(StackTraceElement ste:Thread.currentThread().getStackTrace()) {
            System.out.println(ste.getMethodName());
        }
    }
}
复制代码

输出:

foo
bar
----------------------
getStackTrace
printStackMethods
bar
main

2020年1月19日

posted @   逆火狂飙  阅读(889)  评论(0编辑  收藏  举报
编辑推荐:
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
阅读排行:
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 【杭电多校比赛记录】2025“钉耙编程”中国大学生算法设计春季联赛(1)
生当作人杰 死亦为鬼雄 至今思项羽 不肯过江东
点击右上角即可分享
微信分享提示