Java 獲取當前類名和方法名的實現(xiàn)方法
Java 獲取當前類名和方法名的實現(xiàn)方法 這里提供了四種方法并比較,大家需要的可以參考下,
為了測試各個函數(shù),如果手動打印每個類名、函數(shù)名,那么多函數(shù)的話能把人累死,Java早已準備好了一堆記錄自身的函數(shù)。
獲取類名:
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);
}
執(zhí)行100w次,
第一種方法:1718ms
第二種方法:4843ms
第三種方法:47ms
第四種方法:6484ms
比較:
1)方法1不知有沒有什么使用限制?
2)方法2通過異常機制獲取調用棧,性能最差,但能提供其它方法所不具有的功能,還可以獲取方法名,行號等等;但這么使用多少有點不太常規(guī);
3)方法3只是簡單分析了一下匿名類的名稱,顯然要簡單多,事實上性能也是最高的;
4)方法4感覺和方法3有點類似,比方法3正規(guī)了點
獲取函數(shù)名:
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);
}
執(zhí)行100w次:
第一種:4856ms
第二種:6337ms
說明:
1.Exception類繼承于Throwable,所以有的地方用Exception調用那個getStackTrace,其實調用的還是Throwable的
2.不同的jdk版本調用getStackTrace后得到的數(shù)組不太一樣,下標多試幾次就知道了,以上是jdk1.6版本下的
感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
相關文章
SpringBoot優(yōu)雅實現(xiàn)計算方法執(zhí)行時間
這篇文章主要為大家詳細介紹了SpringBoot中優(yōu)雅實現(xiàn)計算方法執(zhí)行時間的相關方法,文中的示例代碼講解詳細,感興趣的小伙伴可以跟隨小編一起學習一下2025-04-04

