亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

Log信息獲取調用類和調用方法名的實現原理

2019-11-18 12:03:10
字體:
來源:轉載
供稿:網友

  Sun JDK 源代碼下載 http://wwws.sun.com/software/communitysource/
  先注冊并登錄到“Sun Community Source Licensing”,然后下載J2SE(幾十兆)或者J2EE(幾百兆)。
  
  Log能夠把代碼運行時間,類名,方法名,還有信息,全部都打印出來。
  一個直觀的例子,每次啟動Tomcat(缺省配置)的時候。一般可以看到
  Jul 9, 2004 11:22:29 AM org.apache.struts.util.PRopertyMessageResources
  INFO: Initializing, config='org.apache.webapp.admin.applicationResources', returnNull=true
  Jul 9, 2004 11:22:41 AM org.apache.coyote.http11.Http11Protocol start
  INFO: Starting Coyote HTTP/1.1 on port 8080
  
  時間,類名,方法名,信息都打印了出來。
  那么,log是如何獲取調用自身的這個類和這個方法名的呢?
  
  后面給出的代碼是JDK1.4的源代碼,和Log4J的源代碼。說明其實現原理。
  獲得調用類,和方法名,就是需要獲得當前運行棧的結構。
  new Throwable().getStackTrace() 會返回當前運行棧的結構層次。
  利用這種原理,可以獲得整個運行棧的調用關系。
  
  JDK1.4的java.util.logging包, 通過Throwable.getStackTrace()方法實現的。
  // Get the stack trace.
  StackTraceElement stack[] = (new Throwable()).getStackTrace();
  
  完整的代碼在JDK1.4的源代碼里面,java.util.logging.LogRecord類的inferCaller方法。
  
  java代碼:
  2 // Private method to infer the caller's class and method names
  3 private void inferCaller() {
  ...}
  4 needToInferCaller = false;
  5 // Get the stack trace.
  6 StackTraceElement stack[] = (new Throwable()).getStackTrace();
  7 // First, search back to a method in the Logger class.
  8 int ix = 0;
  9 while (ix < stack.length) {
  ...}
  10 StackTraceElement frame = stack[ix];
  11 String cname = frame.getClassName();
  12 if (cname.equals("java.util.logging.Logger")) {
  ...}
  13 break;
  14 }
  15 ix++;
  16 }
  17 // Now search for the first frame before the "Logger" class.
  18 while (ix < stack.length) {
  ...}
  19 StackTraceElement frame = stack[ix];
  20 String cname = frame.getClassName();
  21 if (!cname.equals("java.util.logging.Logger")) {
  ...}
  22 // We've found the relevant frame.
  23 setSourceClassName(cname);
  24 setSourceMethodName(frame.getMethodName());
  25 return;
  26 }
  27 ix++;
  28 }
  29 // We haven't found a suitable frame, so just punt. This is
  30 // OK as we are only commited to making a "best effort" here.
  31 }
  32
  
  Log4j有異曲同工之妙。
  org.apache.log4j.spi.LocationInfo類。
  先用Throwable.printStackTrace()方法把Exception信息打印到一個字符串里。
  然后按行分析這個字符串。抽出調用類和方法。參見LocationInfo類的構造函數。
  
  java代碼:
  1
  2 /**
  3 Instantiate location information based on a Throwable. We
  4 eXPect the Throwable t, to be in the format
  5
  6 

  7 java.lang.Throwable
  8 ...
  9 at org.apache.log4j.PatternLayout.format(PatternLayout.java:413)
  10 at org.apache.log4j.FileAppender.doAppend(FileAppender.java:183)
  11 at org.apache.log4j.Category.callAppenders(Category.java:131)
  12 at org.apache.log4j.Category.log(Category.java:512)
  13 at callers.fully.qualified.className.methodName(FileName.java:74)
  14 ...
  15

  16
  17



發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
午夜美女久久久久爽久久| 在线精品视频视频中文字幕| 国产有码在线一区二区视频| 精品国内亚洲在观看18黄| 日韩欧美精品免费在线| 日韩不卡中文字幕| 欧美成人精品xxx| 日韩一级黄色av| 一区二区成人精品| 亚洲欧美国产精品| 欧美精品激情在线| 在线日韩av观看| 狠狠色狠狠色综合日日五| 久热精品视频在线免费观看| 国产成人精品在线播放| 欧美中文在线观看国产| 久久五月天综合| 国产精品伦子伦免费视频| 日韩免费在线电影| 欧美午夜精品久久久久久人妖| 亚洲国产欧美久久| 久久深夜福利免费观看| 亚洲品质视频自拍网| 亚洲第一天堂av| 日韩中文字幕不卡视频| 久久久亚洲福利精品午夜| 26uuu亚洲国产精品| 波霸ol色综合久久| 亚洲人成电影网站色| 国产欧美久久久久久| 欧美中文字幕在线| 成人精品一区二区三区电影黑人| 国产91精品黑色丝袜高跟鞋| 92版电视剧仙鹤神针在线观看| 日韩精品高清在线观看| 日韩av最新在线| 国产视频精品免费播放| 国产精品免费视频xxxx| 国产欧美一区二区三区视频| 亚洲女人被黑人巨大进入| 91成人天堂久久成人| 亚洲人成人99网站| 国产精品影院在线观看| 九九综合九九综合| 久久男人的天堂| 久久久女女女女999久久| 欧美刺激性大交免费视频| 欧美一级淫片丝袜脚交| 国产精品精品久久久久久| 日韩中文有码在线视频| 亚洲欧美国产另类| 97国产在线视频| 国产一区二区三区视频免费| 久久999免费视频| 51久久精品夜色国产麻豆| 亚洲精品成人av| 岛国av一区二区在线在线观看| 国产成人精品视频| 性欧美长视频免费观看不卡| 国产亚洲精品久久久久久牛牛| 亚州欧美日韩中文视频| 欧美成人午夜剧场免费观看| 欧美日韩亚洲激情| 疯狂欧美牲乱大交777| 欧美在线播放视频| 国产日韩欧美视频在线| 欧美激情视频在线| 中文字幕精品www乱入免费视频| 国产丝袜一区视频在线观看| 欧美日韩中国免费专区在线看| 日韩av在线一区二区| 久久亚洲欧美日韩精品专区| 成人午夜两性视频| 91精品国产91久久| 亚洲在线免费视频| 精品丝袜一区二区三区| 777午夜精品福利在线观看| 日韩欧美中文免费| 成人在线视频网站| 日韩欧美在线观看| 欧美性猛交xxxx黑人猛交| 中文字幕亚洲欧美日韩在线不卡| 亚洲欧美中文日韩在线v日本| 欧美黑人性生活视频| 一区二区成人精品| 国产香蕉一区二区三区在线视频| 亚洲欧美国产一本综合首页| 日韩免费在线电影| 成人a免费视频| 国内自拍欧美激情| 中文字幕成人精品久久不卡| 日韩精品中文字| 欧美日韩一二三四五区| 欧美黑人巨大xxx极品| 国产精品一区二区3区| 自拍偷拍亚洲区| 久久久久国产视频| 成人免费观看49www在线观看| 欧美老少配视频| 国产不卡视频在线| 国产精品视频在线播放| 亚洲精品福利在线观看| 91亚洲精品一区| 日韩成人激情影院| 日韩男女性生活视频| 曰本色欧美视频在线| 欧美性猛交xxxxx水多| 96精品久久久久中文字幕| 国产91免费观看| 久久免费国产视频| 久久免费视频网站| 亚洲品质视频自拍网| 韩国三级日本三级少妇99| 久久成人免费视频| 日韩电视剧在线观看免费网站| 日韩精品亚洲元码| 欧美激情欧美激情在线五月| 久久久久久久久久婷婷| 91在线免费视频| 亚洲日本中文字幕| 欧美日韩成人黄色| 成人激情av在线| 91色精品视频在线| 狠狠色狠色综合曰曰| 久久夜色精品国产欧美乱| 国产视频久久网| 日韩中文视频免费在线观看| 成人日韩av在线| 国产精品 欧美在线| 亚洲网址你懂得| 国产九九精品视频| 国产一区二区免费| 欧美亚洲一区在线| 日韩精品电影网| 亚洲国产精品成人av| 国产在线观看精品一区二区三区| 欧美最猛性xxxxx免费| 美日韩丰满少妇在线观看| 欧美第一黄色网| 懂色av影视一区二区三区| 久久综合色影院| 国产不卡精品视男人的天堂| 深夜精品寂寞黄网站在线观看| 激情av一区二区| 国产精品专区h在线观看| 国产精品免费一区二区三区都可以| 精品毛片三在线观看| 欧美中文字幕视频| 97国产成人精品视频| 久久男人资源视频| 国产精品免费久久久| 亚洲电影在线看| 美日韩精品视频免费看| 懂色av影视一区二区三区| 69久久夜色精品国产69| 欧美精品在线第一页| 中文字幕日韩欧美在线| 国内精品一区二区三区| 亚洲春色另类小说| 精品久久久久久久大神国产| 91免费在线视频| 亚洲精品第一国产综合精品| 97国产精品久久| 91在线观看免费观看|