<!--本文非原创,摘自百度文库的中richardtxws贡献者,完善了里面的内容-->
Java中获取当前函数名、类名、当前类的文件名
方法一:getClass()
获取当前类名:String clazz = this.getClass().getName();
方法二(JDK 5):Thread.currentThread()
在JDK 5中,有三个类拥有getStackTrace方法,
类 返回 方法 注释
ThreadStackTraceElement[] getStackTrace() 返回一个标示该线程堆栈转储的堆栈跟踪元素数组
ThreadInfoStackTraceElement[] getStackTrace() 返回与此ThreadInfo相关的现成的堆栈跟踪
ThrowableStackTraceElement[]getStackTrace() 提供编程访问由printStackTrace()输出的堆栈跟踪信息
此处,我们用Thread.currentThread()中的StackTraceElement来获取当前函数名。在MainApplication.java中的Main方法中测试,具体代码如下:
1. 获取当前函数名:Thread.currentThread().getStackTrace()[1].getMethodName(); 得到 main
2. 获取当前类名:Thread.currentThread().getStackTrace()[1].getClassName(); 得到mainapplication.MainApplication
3. 获取当前类的文件名:Thread.currentThread().getStackTrace()[1].getFileName(); 得到MainApplication.java
方法三:可在静态方法使用
静态方法不与特定实例关联,不能引用this,要得到当前类名,没有直接的办法。
通过查资料和试验,可以用下面几种方式:
//方法1:通过SecurityManager的保护方法getClassContext()
public static void main(String[] args) {
String name = new SecurityManager(){
public String getClassName(){
return this.getClassContext()[1].getName();
}
}.getClassName();
System.out.println(name);
}
//方法2:通过Throwable的方法getStackTrace()
public static void main(String[] args) {
String name = new Throwable().getStackTrace()[0].getClassName();
System.out.println(name);
}
</pre><p></p><p><span style="color:rgb(255,0,0)"><span style="font-size:14px">//<span style="font-family:宋体">方法</span><span style="font-family:Times New Roman">3</span><span style="font-family:宋体">:通过分析匿名类名称</span><span style="font-family:Times New Roman">()</span></span></span></p><p></p><pre name="code" class="java"> public static void main(String[] args) {
String name = new Object(){
public String getClassName(){
return this.getClass().getName().replaceFirst("[$][1]", "");
}
}.getClassName();
System.out.println(name);
}
分别调用10万次,
方法1:219ms
方法2:953ms
方法3:31ms
比较:
1)方法1不知有没有什么使用限制?
2)方法2通过异常机制获取调用栈,性能最差,但能提供其它方法所不具有的功能,还可以获取方法名,行号等等;但这么使用多少有点不太常规;
3)方法3只是简单分析了一下匿名类的名称,显然要简单多,事实上性能也是最高的;