瘋狂

          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中區分具體是哪個方法調用的?
          主站蜘蛛池模板: 康平县| 禄丰县| 湟中县| 新闻| 海丰县| 肥城市| 安康市| 绥芬河市| 广汉市| 贵定县| 大关县| 阿拉尔市| 台中县| 阳曲县| 泰宁县| 临猗县| 江阴市| 中超| 宁夏| 通化市| 克拉玛依市| 花垣县| 德化县| 呼玛县| 永昌县| 荥阳市| 奈曼旗| 册亨县| 冀州市| 合江县| 内丘县| 拉萨市| 和林格尔县| 南川市| 滦南县| 安吉县| 平阳县| 茌平县| 潜山县| 九江市| 磐安县|