这篇文章主要介绍了 Java 获取当前类名和方法名的实现方法的相关资料,这里不仅提供了实现方法并比较几种方法的效率,需要的朋友可以参考下
方法/步骤
1
Java 获取当前类名和方法名的实现方法 这里提供了四种方法并比较,大家需要的可以参考下, 为了测试各个函数,如果手动打印每个类名、函数名,那么多函数的话能把人累死,Java早已准备好了一堆记录自身的函数。获取类名:
2
执行100w次,第一种方法:1718ms第二种方法:4843ms第三种方法:47ms第四种方法:6484ms
3
比较: 1)方法1不知有没有什么使用限制? 2)方法2通过异常机制获取调用栈,性能最差,但能提供其它方法所不具有的功能,还可以获取方法名,行号等等;但这么使用多少有点不太常规; 3)方法3只是简单分析了一下匿名类的名称,显然要简单多,事实上性能也是最高的; 4)方法4感觉和方法3有点类似,比方法3正规了点获取函数名:
4
执行100w次:第一种:4856ms第二种:6337ms
5
说明:1.Exception类继承于Throwable,所以有的地方用Exception调用那个getStackTrace,其实调用的还是Throwable的2.不同的jdk版本调用getStackTrace后得到的数组不太一样,下标多试几次就知道了,以上是jdk1.6版本下的
上一篇:java基础3.6.2 编码规范