欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

Java 获取当前类名和方法名的实现方法

程序员文章站 2024-01-12 16:38:10
 java 获取当前类名和方法名的实现方法 这里提供了四种方法并比较,大家需要的可以参考下,      &nb...

 java 获取当前类名和方法名的实现方法 这里提供了四种方法并比较,大家需要的可以参考下,

         为了测试各个函数,如果手动打印每个类名、函数名,那么多函数的话能把人累死,java早已准备好了一堆记录自身的函数。

获取类名:

public static void testgetclassname() { 
  // 方法1:通过securitymanager的保护方法getclasscontext() 
  string clazzname = new securitymanager() { 
    public string getclassname() { 
      return getclasscontext()[1].getname(); 
    } 
  }.getclassname(); 
  system.out.println(clazzname); 
  // 方法2:通过throwable的方法getstacktrace() 
  string clazzname2 = new throwable().getstacktrace()[1].getclassname(); 
  system.out.println(clazzname2); 
  // 方法3:通过分析匿名类名称() 
  string clazzname3 = new object() { 
    public string getclassname() { 
      string clazzname = this.getclass().getname(); 
      return clazzname.substring(0, clazzname.lastindexof('$')); 
    } 
  }.getclassname(); 
  system.out.println(clazzname3); 
  //方法4:通过thread的方法getstacktrace() 
  string clazzname4 = thread.currentthread().getstacktrace()[2].getclassname(); 
  system.out.println(clazzname4); 
} 

 执行100w次,

第一种方法:1718ms
第二种方法:4843ms
第三种方法:47ms
第四种方法:6484ms

比较:

    1)方法1不知有没有什么使用限制?
    2)方法2通过异常机制获取调用栈,性能最差,但能提供其它方法所不具有的功能,还可以获取方法名,行号等等;但这么使用多少有点不太常规;
    3)方法3只是简单分析了一下匿名类的名称,显然要简单多,事实上性能也是最高的;
    4)方法4感觉和方法3有点类似,比方法3正规了点

获取函数名:

public static void testgetfunctionname() { 
    // 方法1:通过throwable的方法getstacktrace() 
    string funcname2 = new throwable().getstacktrace()[1].getmethodname(); 
    system.out.println(funcname2); 
    //方法2:通过thread的方法getstacktrace() 
    string clazzname4 = thread.currentthread().getstacktrace()[2].getmethodname(); 
    system.out.println(clazzname4);  
  } 

执行100w次:

第一种:4856ms
第二种:6337ms 

说明:

1.exception类继承于throwable,所以有的地方用exception调用那个getstacktrace,其实调用的还是throwable的
2.不同的jdk版本调用getstacktrace后得到的数组不太一样,下标多试几次就知道了,以上是jdk1.6版本下的

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!