美文网首页
获取java调用者信息

获取java调用者信息

作者: 周周s周小明 | 来源:发表于2017-06-16 11:11 被阅读51次

现在好多代码解耦特别严重,调用者也是特别多,以下代码获取某块代码的调用者信息,打印到控制台中。


    public static void printCaller() {
        try {
            StackTraceElement[] trace = new Throwable().fillInStackTrace().getStackTrace();
            String caller = "";
            String callingClass = "";
            String callFile = "";
            int lineNumber = 0;
            System.out.println("==========BEGIN OF CALLER INFO============");
            for (int i = 2; i < trace.length; i++) {
                callingClass = trace[i].getClassName();
                callingClass = callingClass.substring(callingClass
                        .lastIndexOf('.') + 1);
                caller = trace[i].getMethodName();
                callFile = trace[i].getFileName();
                lineNumber = trace[i].getLineNumber();
                String method = String.format(Locale.US, "[%03d] %s.%s(%s:%d)"
                        , Thread.currentThread().getId(), callingClass, caller, callFile, lineNumber);
                System.out.println(method);
            }
            System.out.println("==========END OF CALLER INFO============");
        } catch (Exception e) {
            e.printStackTrace();
        }
    }

相关文章

网友评论

      本文标题:获取java调用者信息

      本文链接:https://www.haomeiwen.com/subject/coipqxtx.html