获取java调用者信息

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


    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();
        }
    }

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 174,385评论 25 709
  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,834评论 18 399
  • 对你还保留幻想 对你还保留爱恋 可是我要走了 我舍弃了这段相思 舍弃了对你不舍 该走了,不会留恋 该走了,不会流泪...
    妹妹躲雨吗阅读 188评论 0 0
  • 我猜你2017会过得更好 1、 学校有这么一习俗,一旦有人告白成功就会放烟花。 最近的烟花声有点多,我一朋友却失恋...
    胡小小小云阅读 393评论 0 0
  • 《草》 我只是一株默默等候的草 你离开的时候 是我枯萎的季节 《落》 我猜你是走丢了 满世界找你 却不敢去我们...
    段兰台阅读 176评论 0 0