Java继承和多态
10 Java异常处理
10.1 Java异常处理
10.2 Java中Error和Exception的异同
10.3 Java异常处理机制
10.4 Java try catch语句详解
10.5 【Java项目实战】计算平均成绩
10.6 Java try catch finally语句
10.7 Java finally和return的执行顺序(非常重要)
10.8 Java 9增强的自动资源管理
10.9 Java声明和抛出异常
10.10 Java 7新特性之多异常捕获
10.11 Java自定义异常
10.12 Java验证用户信息
10.13 【Java示例】完善除法运算的错误信息
10.14 Java异常处理规则(新手必看)
10.15 Java的异常跟踪栈
10.16 Java.util.logging记录日志
Java集合、泛型和枚举 Java反射机制 Java输入/输出流 Java注解
每个初学者都很熟悉在有问题的代码中使用 System.out.println 方法在控制台打印消息,来帮助观察程序运行的操作过程。如果你使用  System.out.println 方法,一旦发现问题的根源,就要将这些语句从代码中删去。如果接下来又出现了问题,就需要再插入几个调用 System.out.println 方法的语句,如此反复,增加了工作量。
日志用来记录程序的运行轨迹,方便查找关键信息,也方便快速定位解决问题。下面介绍 Java 自带的日志工具类 java.util.logging 的使用。
如果要生成简单的日志记录,可以使用全局日志记录器并调用其 info 方法,代码如下:
Logger.getGlobal().info("打印信息"); JDK Logging 把日志分为如下表 7 个级别,等级依次降低。
Logger 的默认级别是 INFO,比 INFO 级别低的日志将不显示。Logger 的默认级别定义在 jre 安装目录的 lib 下面。 # Limit the message that are printed on the console to INFO and above.
java.util.logging.ConsoleHandler.level = INFO

所以在默认情况下,日志只显示前三个级别,对于所有的级别有下面几种记录方法: logger.warning(message);
logger.fine(message);

同时,还可以使用 log 方法指定级别,例如: logger.log(Level.FINE, message);

public class Test { private static Logger log = Logger.getLogger(Test.class.toString()); public static void main(String[] args) { // 级别依次升高,后面的日志级别会屏蔽之前的级别 log.finest("finest"); log.finer("finer"); log.fine("fine"); log.config("config"); log.info("info"); log.warning("warning"); log.severe("server"); 输出结果为: 十一月 27, 2019 5:13:05 下午 Test.Test main
信息: info
十一月 27, 2019 5:13:05 下午 Test.Test main
警告: warning
十一月 27, 2019 5:13:05 下午 Test.Test main
严重: server

可以使用 setLevel 方法设置级别,例如 logger.setLevel(Level.FINE); 可以将 FINE 和更高级别的都记录下来。另外,还可以使用 Level.ALL 开启所有级别的记录,或者使用 Level.OFF 关闭所有级别的记录。
注意:如果将记录级别设计为 INFO 或者更低,则需要修改日志处理器的配置。默认的日志处理器不会处理低于 INFO 级别的信息。
修改日志管理器配置 可以通过编辑配置文件来修改日志系统的各种属性。在默认情况下,配置文件存在于 jre 安装目录下“jre/lib/logging.properties”。要想使用另一个配置文件,就要将 java.util.logging.config.file 特性设置为配置文件的存储位置,并用下列命令启动应用程序。 java -Djava.util.logging.config.file = configFile MainClass

日志管理器在 JVM 启动过程中初始化,这在 main 执行之前完成。如果在 main 中调用 System.setProperty("java.util.logging.config.file",file) ,也会调用 LogManager.readConfiguration() 来重新初始化日志管理器。
要想修改默认的日志记录级别,就需要编辑配置文件,并修改以下命令行。 .level=INFO

可以通过添加以下内容来指定自己的日志记录级别 Test.Test.level=FINE

也就是说,在日志记录器名后面添加后缀 .level。
在稍后可以看到,日志记录并不将消息发送到控制台上,这是处理器的任务。另外,处理器也有级别。要想在控制台上看到 FINE 级别的消息,就需要进行下列设置。 java.util.logging.ConsoleHandler.level=FINE

注意:在日志管理器配置的属性设置不是系统属性,因此,用 -Dcom.mycompany.myapp.level=FINE 启动应用程序不会对日志记录器产生任何影响。

关注公众号「 站长严长生 」,在手机上阅读所有教程,随时随地都能学习。内含一款搜索神器,免费下载全网书籍和视频。

微信扫码关注公众号