java打印當(dāng)前方法名示例分享
在C與C++中可以這樣打印當(dāng)前函數(shù)名:
printf("%s",__func__);
但在Java沒有此說法,一切即對象,得從某個對象中去獲取,可分為兩種方式:
第一種:通過Thread類來獲取。
System.out.println(Thread.currentThread().getStackTrace()[1].getMethodName());
System.out.println(Thread.currentThread().getStackTrace()[1].getClassName());
第二種:通過Throwable類來獲取,第二種方法有可以擴展,只要是throwable的子類都可以實現(xiàn)功能。
System.out.println(new Throwable().getStackTrace()[0].getMethodName());
System.out.println(new Throwable().getStackTrace()[0].getClassName());
通過此兩種方法能打印出當(dāng)前方法名和所在的類名,但有一個弊端就是如下index:
getStackTrace()[index]
取什么值,0或者1還是其他數(shù)值,在這里兩種方式的index分別寫成0和1,就是用來提醒自己,它不是固定不變的,需要自己通過測試確定下來。據(jù)說JDK的版本不一樣取值可能不一樣。但沒親自測試過。
我測試用的JDK版本:java version "1.7.0_17"
相關(guān)文章
Springboot如何設(shè)置靜態(tài)資源緩存一年
這篇文章主要介紹了Springboot如何設(shè)置靜態(tài)資源緩存一年,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2019-11-11java 實現(xiàn)簡單圣誕樹的示例代碼(圣誕節(jié)快樂)
這篇文章主要介紹了java 實現(xiàn)簡單圣誕樹的示例代碼(圣誕節(jié)快樂),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-12-12