Java获取调用当前方法的方法名和行数(亲测可行)

有时候一个方法被很多方法调用了,但是在调试应用程序的时候,需要知道是哪个方法调用它的,方便定位bug问题。否者,比较难以理清和解决一些bug问题。

适用:任何适用java语言编程的地方,java后端和android端。

以下是我总结的工具打印方法。你也可以基于此方法进行定制,可以打印完整的调用栈信息。

c 复制代码
package utils;

/**
 * 日之类测试方法
 */
public class LogsUtilsTest {

    public static void main(String[] args) {
        parentMethod01();
        parentMethod03();
        parentMethod05();
    }
    private static void parentMethod01(){
        childMethod();
    }

    private static void parentMethod02(){
        childMethod();
    }
    private static void parentMethod03(){
        childMethod();
    }
    private static void parentMethod04(){
        childMethod();
    }
    private static void parentMethod05(){
        childMethod();
    }
    private static  void childMethod(){
        System.out.println("childMethod StackTrace:"+LogUtils.getParentClassStackTrace(LogsUtilsTest.class.getName()));
    }
}
c 复制代码
package utils;

/**
 * 日志工具类
 */
public class LogUtils {

    /**
     * 获取当前方法调用的类名+方法+代码行
     * @param currClassName
     * @return
     */
    public static  String  getParentClassStackTrace(String currClassName){
        StackTraceElement[] stackTrace = Thread.currentThread().getStackTrace();
        StackTraceElement log = stackTrace[2];
        String tag = null;
        int parent=0;
        for (int i = 1; i < stackTrace.length; i++) {
            StackTraceElement e = stackTrace[i];
            if(e.getClassName().equals(currClassName)){
                parent=i;
                break;
            }
        }
        StackTraceElement parentStack = stackTrace[parent+1];
        tag = "《"+parentStack.getClassName() + "》.《" + parentStack.getMethodName()+"》.《"+parentStack.getLineNumber()+"》";
        if (tag == null) {
            tag = log.getClassName() + "." + log.getMethodName()+"."+log.getFileName()+"."+log.getLineNumber();

        }
        return tag;
    }
}

代码运行打印:

相关推荐
JosieBook5 分钟前
【SpringBoot】37 核心功能 - 高级特性- Spring Boot 中的 自定义 Starter 完整教程
java·spring boot·后端
小二·24 分钟前
Elasticsearch 面试题精编(26题|含答案|分类整理)
java·大数据·elasticsearch
BD_Marathon33 分钟前
在 Linux 环境中配置 Eclipse 以开发 Hadoop 应用
java·hadoop·eclipse
草莓熊Lotso1 小时前
C++ 二叉搜索树(BST)完全指南:从概念原理、核心操作到底层实现
java·运维·开发语言·c++·人工智能·经验分享·c++进阶
oliveira-time1 小时前
单例模式中的饿汉式
java·开发语言
凌波粒1 小时前
SpringMVC基础教程(1)--MVC/DispathcerServlet
java·spring·mvc
武子康1 小时前
Java-173 Neo4j + Spring Boot 实战:从 Driver 到 Repository 的整合与踩坑
java·数据库·spring boot·后端·spring·nosql·neo4j
凌波粒1 小时前
SpringMVC基础教程(2)--Controller/RestFul风格/JSON/数据转发和重定向
java·后端·spring·json·restful
老鼠只爱大米2 小时前
Java 设计模式之适配器模式:系统集成的万能接口
java·设计模式·适配器模式·adapter·java设计模式
一叶飘零_sweeeet2 小时前
Java+EasyExcel 打造学习平台视频学习时长统计系统
java·报表·easyexcel