用Java日志包进行调试

原创 2004年10月15日 08:52:00
作者: Builder.com
Tuesday, April 6 2004 11:23 AM

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

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

advertisement_e1.gif
PCPro_MPU.swf PCPro_MPU.swf PCPro_MPU.swf code;sz=1x1;ord=561814338?

你可以在不安装的前提下使用日志包。其中最简单的方法就是建立一个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或是其他级别。你也可能需要记录一些关于控制台的信息,或是一些关于文件的信息,甚至有时是关于数据库的信息。



责任编辑:李宁

欢迎评论投稿


本文为ZDNet China版权所有,未经许可严禁转载。

用Java日志包进行调试

用Java日志包进行调试Builder.com 6/4/2004 URL: http://www.zdnet.com.cn/developer/code/story/0,2000081534,3922...
  • cenlop
  • cenlop
  • 2004年09月16日 11:51
  • 1795

Java程序调试与日志进阶

 概述本文根据作者的开发经验叙述了对Java程序调试和日志的认识和理解。介绍了System.out.println, System.out.printf,手工制作的小工具类SysUtils.log,l...
  • KimSoft
  • KimSoft
  • 2008年11月18日 13:50
  • 5381

调试临时日志输出

一、非控制台程序也可使用控制台输出 1、AllocConsole为当前进程分配一个控制台 2、在程序中调用printf, cout等函数即可 3、FreeConsole不使用时调用释放控制台   如下...
  • s634772208
  • s634772208
  • 2015年10月24日 13:12
  • 458

程序调试的利器—日志

第1部分 重新认识C语言 程序调试的利器—日志           如果世界上有一个人能够保证一次写出来的代码是百分之百正确的,那么毫无疑问,他一定是世界上最优秀的程序员,没有之一。...
  • liuxiaoxiaosmile
  • liuxiaoxiaosmile
  • 2014年05月23日 21:36
  • 2055

java调试jar包时关联源码的方法

问题:        最近在一个项目中调试另外一个jar包,项目源代码和jar包源代码都在同一个工作空间下,但是发现断点进到的是.class文件而不是源文件。 解决方法:       在启动调试...
  • xiaoxiaoyusheng2012
  • xiaoxiaoyusheng2012
  • 2016年10月08日 13:56
  • 1731

查看签名apk调试日志工具

Android Studio可以调试debug apk,通过logcat查看日志;可并不能用来调试经过签名的release apk,这时候可以考虑用Eclipse的logcat查看签名的apk日志,但...
  • Peak1Chen
  • Peak1Chen
  • 2016年06月02日 10:35
  • 1025

如何通过日志来调试Web App

我们可以通过JavaScript的控制台API输出信息到Android的logcat上来跟踪WebView加载网页时发生的异常或错误的原因,以此来对Web App进行调试。 在Android浏览器中...
  • hugh282003
  • hugh282003
  • 2014年02月14日 15:34
  • 5394

重新编译JDK的src.zip=>rt_debug.jar,使调试可以进入系统类审查变量

1.问题的出现       不知道什么时候开始(估计使sun被Oracle收购之后吧)eclipse调试系统类F5进不去了,或者进去不能看到局部变量的值,Oracle这个大龟壳总是担心被别人知道它的...
  • yyyuuueeee
  • yyyuuueeee
  • 2017年03月26日 18:55
  • 837

如何用Myeclipse进行调试

以前一直不知道怎么调试,
  • ligengk
  • ligengk
  • 2014年08月26日 10:34
  • 5505

unity 真机调试

1、配置eclipse环境:首先在官网下载安装包:http://developer.android.com/sdk/index.html,点击这个按钮开始下载    进入下一页,选择对应你系统的版...
  • luyuncsd123
  • luyuncsd123
  • 2014年01月01日 17:34
  • 8082
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:用Java日志包进行调试
举报原因:
原因补充:

(最多只允许输入30个字)