瘋狂

          STANDING ON THE SHOULDERS OF GIANTS
          posts - 481, comments - 486, trackbacks - 0, articles - 1
            BlogJava :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

          java獲取方法調用者信息的例子

          Posted on 2010-01-14 10:33 瘋狂 閱讀(8847) 評論(1)  編輯  收藏 所屬分類: java
          通過ThreadgetStackTrace()我們可以獲取當前線程的運行信息 ,通過此方法可以獲取我們想要的調用者信息:
          例子:被調用者T2.java
          public class T2 {

              
              
          public void t2Method(){
                  getCaller();
              }

              
          public  void  getCaller(){   
                     StackTraceElement stack[] 
          = Thread.currentThread().getStackTrace();  
                     
          for (StackTraceElement ste:stack){   
                      
          if((ste.getClassName().indexOf("T1"))!=-1){
                          System.out.println("
          called by "+ste.getClassName()+"."+ste.getMethodName()+"/"+ste.getFileName());
                      }

                     }
             
                   }
            

          }
          調用者:
          T1.java
          public class T1 {

              
              
          public static void main(String[] args) {
                  
          new T2().t2Method();

              }


          }
          運行顯示:
          called by com.test.T1.main/T1.java
           

          評論

          # re: java獲取方法調用者信息的例子[未登錄]  回復  更多評論   

          2014-09-23 11:58 by sky
          有個小問題想問下,比如我在T1中有個兩個同名稱的方法參數不同
          都調用了 t2Method方法,這個時候我怎么在getCaller中區分具體是哪個方法調用的?
          主站蜘蛛池模板: 老河口市| 鹿泉市| 济源市| 榕江县| 会泽县| 宿松县| 岚皋县| 鸡东县| 巫山县| 怀来县| 嘉黎县| 临泽县| 滨州市| 龙南县| 正阳县| 连城县| 出国| 河曲县| 长治县| 永仁县| 黄冈市| 大石桥市| 页游| 蓝山县| 公主岭市| 邢台市| 和龙市| 云林县| 仙居县| 南开区| 板桥市| 霍邱县| 察雅县| 延庆县| 团风县| 濮阳县| 渭南市| 太白县| 墨竹工卡县| 布拖县| 云阳县|