zoukankan      html  css  js  c++  java
  • Java: 获取当前执行位置的文件名/类名/方法名/行号

    在 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 debug CurrentLineInfo

    下面是源码和测试:

    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
    
  • 相关阅读:
    [LeetCode] 85. 最大矩形
    [LeetCode] 84. 柱状图中最大的矩形
    [LeetCode] 83. 删除排序链表中的重复元素
    [LeetCode] 81. 搜索旋转排序数组 II
    [LeetCode] 82. 删除排序链表中的重复元素 II
    [LeetCode] 80. 删除排序数组中的重复项 II
    [LeetCode] 79. 单词搜索
    [LeetCode] 77. 组合
    转:快乐Node码农的十个习惯
    转:zookeeper3.4.5安装笔记
  • 原文地址:https://www.cnblogs.com/xiaozhang9/p/6666899.html
Copyright © 2011-2022 走看看