汪亮ID:cenlop
25596次访问,排名4522(1)好友0人,关注者0
cenlop的文章
原创 31 篇
翻译 0 篇
转载 0 篇
评论 9 篇
cenlop的公告

【个人简介】:
网名:一路编程
cenlo@126.com
来自:湖北黄冈


最近评论
fftaks:Wow gold
fenglibing:TKS
keiki:thx a lot:)
t608:非常好的收集
mysyche:hao hao hao aho aho aho
文章分类
    收藏
      相册
      我的相册
      我的照片
      JAVA语言
      存档
      软件项目交易
      订阅我的博客
      XML聚合  FeedSky
      订阅到鲜果
      订阅到Google
      订阅到抓虾
      订阅到BlogLines
      订阅到Yahoo
      订阅到GouGou
      订阅到飞鸽
      订阅到Rojo
      订阅到newsgator
      订阅到netvibes

      原创 用Java日志包进行调试收藏

       | 旧一篇: Velocity -- Java Web 开发新技术

      用Java日志包进行调试
      Builder.com
      6/4/2004
      URL: http://www.zdnet.com.cn/developer/code/story/0,2000081534,39225509,00.htm

      本文译自Builder.com,未经许可请勿转载

      在JAVA1.4引入了一个日志包java.util.logging。如果你已经使用过以前的普通日志结构框架——log4j的话,那么有关Java的内部记录部分你将非常熟悉了。

      你可以在不安装的前提下使用日志包。其中最简单的方法就是建立一个Java.util.logging.Logger的实例。一旦建立好这个实例,你就可以开始记录了。下面是一个记录类的完整例子:

      package tips;

      import java.util.logging.Logger;

      public class LogTip {
          // create an instance of the Logger class
          private static Logger log = Logger.getLogger("tips.LogTip");

          public static void main(String args[]) {
              log.finest("the finest message");
              log.finer("finer message");
              log.fine("a fine message");
              log.config("some configuration message");
              log.info("a little bit of information");
              log.warning("a warning message");
              log.severe("a severe message");
          }
      }

      你在编译运行这个类的时候,你的控制台中就会有以下的输出显示:

      Apr 1, 2003 11:09:05 PM tips.LogTip main
      INFO: a little bit of information
      Apr 1, 2003 11:09:05 PM tips.LogTip main
      WARNING: a warning message
      Apr 1, 2003 11:09:05 PM tips.LogTip main
      SEVERE: a severe message

      并不是所有的记录项都会显示在控制台中,这是因为Java的日志包应用了日志级别别。日志级别允许你控制记录输出。在开发过程中,你希望得到大量的调试信息,从而你可以了解你的应用程序将会出现什么问题。

      但作为产品,你就不希望他输出调试结果并且不出错。你也可以通过使用日志包中的日志级别别来控制。

      在Java.util.logging.Level这个类中定义了7种日志级别别,他们分别是:SEVERE,WARNING, INFO,CONFIG,FINE, FINER和FINEST。其中SEVERE即用于处理错误以及灾难事件。而FINE,FINER和FINEST级是用于处理一些不那么重要的信息,以及用于程序调试。

      另外,你可以将日志级别别设定为ALL或者OFF来设定它的极值。当你将其设定为ALL的时候,所有的记录项都为开放的,相反,当你设定为OFF的时候,所有的记录项都为禁止的。

      由于日志级别别是分层次的,当你将其定义为某一级别后,就只有此级别或是更高级别的能被记录。在七种级别中SEVERE是最高级别,FINEST是最低级别。默认级别是INFO;这就是我们在上面代码段中只看到三个记录信息的原因。如果想看到所有的记录信息的话,我们就要改变一下设置。

      有很多方法来改变默认设置,比如用工具文件,对运行时间编程或是提出你自己的结构类。如果你通过工具选项来设置记录的话,你有两种选择,一是你可以用默认的道具文件(这种方法不推荐)——%YOUR_JRE_PATH%/lib/logging.properties;还有就是你可以通过设定系统文件java.util.logging.config.file,将其指定到你需要使用的文件名自己设置道具文件,方法如下:

      java -Djava.util.logging.config.file=log.properties tips.LogTip。

      这样的话不能从log.properties文件中度出任何地记录工具,在这个例子中,这是默认的logging.properties文件的改版,具体如下:

      handlers= java.util.logging.ConsoleHandler
         .level=FINEST
         java.util.logging.ConsoleHandler.level = FINEST
          java.util.logging.ConsoleHandler.formatter = java.util.logging.SimpleFormatter

      当运行这个类的时候,就会有以下的输出显示:

      Apr 1, 2003 11:12:00 PM tips.LogTip main
      FINEST: the finest message
      Apr 1, 2003 11:12:00 PM tips.LogTip main
      FINER: finer message
      Apr 1, 2003 11:12:00 PM tips.LogTip main
      FINE: a fine message
      Apr 1, 2003 11:12:00 PM tips.LogTip main
      CONFIG: some configuration message
      Apr 1, 2003 11:12:00 PM tips.LogTip main
      INFO: a little bit of information
      Apr 1, 2003 11:12:00 PM tips.LogTip main
      WARNING: a warning message
      Apr 1, 2003 11:12:00 PM tips.LogTip main
      SEVERE: a severe message

      在实际应用中,你需要对记录尽可能多的控制。你学要将某些记录定义为FINEST,某些类记录为SEVERE或是其他级别。你也可能需要记录一些关于控制台的信息,或是一些关于文件的信息,甚至有时是关于数据库的信息。

      发表于 @ 2004年09月16日 11:51:00|评论(loading...)|编辑

       | 旧一篇: Velocity -- Java Web 开发新技术

      评论:没有评论。

      发表评论  


      当前用户设置只有注册用户才能发表评论。如果你没有登录,请点击登录
      Csdn Blog version 3.1a
      Copyright © cenlop