Chinaunix首页 | 论坛 | 博客
  • 博客访问: 30492970
  • 博文数量: 708
  • 博客积分: 12163
  • 博客等级: 上将
  • 技术积分: 8240
  • 用 户 组: 普通用户
  • 注册时间: 2007-12-04 20:59
文章分类

全部博文(708)

分类: Java

2008-03-17 11:39:08

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日志级别别,他是:SEVEREWARNING INFOCONFIGFINE FINERFINEST。其中SEVERE即用于错误以及灾事件。而FINEFINERFINEST是用于理一些不那重要的信息,以及用于程序调试

另外,你可以将日志级别别设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或是其他级别。你也可能需要记录一些于控制台的信息,或是一些于文件的信息,甚至有于数据的信息。

阅读(734) | 评论(0) | 转发(0) |
0

上一篇:JAVA中的时间操作

下一篇:Java日志功能

给主人留下些什么吧!~~