<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    走自己的路

    路漫漫其修遠兮,吾將上下而求索

      BlogJava :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理 ::
      50 隨筆 :: 4 文章 :: 118 評論 :: 0 Trackbacks
     
    1. Log4j debug log api不夠豐富

    在進入,退出方法時針對方法的輸入參數和返回值進行log,log中含有方法信息

    logDebugOnMethodEntry, logDebugOnMethodExit

    1. log級別問題

    如果log級別設置的是info,會把warning,error,fatal都打出來,各個級別不能單獨控制。增加各級別分開控制開關。

    1. log格式的定制

    可以定制log信息的pattern,這樣會看起來很統一,log分析起來也容易logDebug(String pattern, Object... paramValues);

    還有一個好處,不需要預先把相關String都append起來,提高performance

    1. log.isDebugEnabled();

    參考第三點,這樣就避免了Object的toString和String的concat操作。

    1. EmptyLogger

    每次記log時,log4j都需要判斷這個級別是否可以打log。如果logger的每個級別都有對應的logger實例,如果debug level被關了,debug級別對應的實例就是EmptyLogger,EmptyLogger里面所有方法的實現都是空的,就不需要這額外的判斷了。




    posted on 2009-12-25 15:09 叱咤紅人 閱讀(2855) 評論(2)  編輯  收藏 所屬分類: Design and Analysis Pattern J2SE and JVM

    評論

    # re: 對Log4j封裝的一些想法[未登錄] 2009-12-26 09:15 aaa
    關于isDebugEnabled,你就算實現了一個空的EmptyLogger也沒有用吧。
    我記得寫log.isDebugEnabled是為了防止某些字符串拼接的開銷。
    比如log.debug(xxx+xxx+xxx);  回復  更多評論
      

    # re: 對Log4j封裝的一些想法 2009-12-27 09:47 叱咤紅人
    @aaa
    是的,是我記混了。我們公司有一個log framework對Log4J做了一層封裝,把log的方法的參數都改成String了,但還有一些提供的方法,會把object都toString后再調用那些封裝過的參數為String的log方法,所以出現了預先toString的情況。于是我們在寫的時候也需要isDebugEnabled。沒有和log4j的區分清楚,已經改正,您說的是我說的第四點,現在的第三點,恩,謝謝提醒。

      回復  更多評論
      

    主站蜘蛛池模板: 亚洲午夜久久影院| 亚洲heyzo专区无码综合| 97热久久免费频精品99 | 国产偷国产偷亚洲清高APP| 亚洲中文字幕无码爆乳av中文| 久久精品乱子伦免费| 亚洲日韩一中文字暮| 亚洲夜夜欢A∨一区二区三区| 亚洲一级免费毛片| 免费国产草莓视频在线观看黄| 久久亚洲AV无码精品色午夜麻| 午夜爱爱免费视频| 精品亚洲永久免费精品| 亚洲AV成人精品一区二区三区| 亚洲一区二区三区高清| 免费真实播放国产乱子伦| 最近高清中文字幕免费| 高清免费久久午夜精品| 精品亚洲成在人线AV无码| 中文字幕精品亚洲无线码二区| 成人au免费视频影院| 少妇太爽了在线观看免费视频| 美女又黄又免费的视频| 亚洲日韩国产精品无码av| 国产AV无码专区亚洲AV手机麻豆 | 亚洲成av人在片观看| 最刺激黄a大片免费网站| 农村寡妇一级毛片免费看视频| 亚洲kkk4444在线观看| 亚洲av福利无码无一区二区 | 亚洲美女精品视频| 亚洲综合久久夜AV | 四虎成人免费观看在线网址| 99热在线观看免费| 久久er国产精品免费观看8| 亚洲av日韩av永久无码电影| 亚洲人成网站看在线播放| 亚洲黄网在线观看| 亚洲2022国产成人精品无码区| 国产成人亚洲综合| 亚洲AV无码乱码在线观看牲色|