Java 获取当前类名和方法名的实现方法
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版本下的
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
上一篇:详解SpringBoot集成Redis来实现缓存技术方案
栏 目:JAVA代码
本文标题:Java 获取当前类名和方法名的实现方法
本文地址:http://www.codeinn.net/misctech/142706.html


阅读排行
- 1Java Swing组件BoxLayout布局用法示例
- 2java中-jar 与nohup的对比
- 3Java邮件发送程序(可以同时发给多个地址、可以带附件)
- 4Caused by: java.lang.ClassNotFoundException: org.objectweb.asm.Type异常
- 5Java中自定义异常详解及实例代码
- 6深入理解Java中的克隆
- 7java读取excel文件的两种方法
- 8解析SpringSecurity+JWT认证流程实现
- 9spring boot里增加表单验证hibernate-validator并在freemarker模板里显示错误信息(推荐)
- 10深入解析java虚拟机




