瘋狂

          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中區分具體是哪個方法調用的?
          主站蜘蛛池模板: 吉林市| 额敏县| 德清县| 高平市| 井研县| 开原市| 石阡县| 东海县| 常德市| 双江| 固安县| 河津市| 句容市| 灌云县| 邯郸县| 沂南县| 乡城县| 定南县| 榆树市| 镇康县| 广饶县| 土默特右旗| 东源县| 营口市| 南郑县| 德安县| 玛多县| 乐平市| 临夏县| 乡城县| 甘南县| 淮阳县| 会宁县| 通城县| 温宿县| 尼勒克县| 普陀区| 偃师市| 清远市| 随州市| 从江县|