這篇文章主要介紹了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
##比較:
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); }
##第一種:4856ms
1.Exception類別繼承於Throwable,所以有的地方用Exception呼叫那個getStackTrace,其實呼叫的還是Throwable的
以上是關於Java如何取得目前類別名稱以及方法名稱的實例的詳細內容。更多資訊請關注PHP中文網其他相關文章!