Java学习者论坛

 找回密码
 立即注册

QQ登录

只需一步,快速开始

手机号码,快捷登录

恭喜Java学习者论坛(https://www.javaxxz.com)已经为数万Java学习者服务超过8年了!积累会员资料超过10000G+
成为本站VIP会员,下载本站10000G+会员资源,购买链接:点击进入购买VIP会员
JAVA高级面试进阶视频教程Java架构师系统进阶VIP课程

分布式高可用全栈开发微服务教程

Go语言视频零基础入门到精通

Java架构师3期(课件+源码)

Java开发全终端实战租房项目视频教程

SpringBoot2.X入门到高级使用教程

大数据培训第六期全套视频教程

深度学习(CNN RNN GAN)算法原理

Java亿级流量电商系统视频教程

互联网架构师视频教程

年薪50万Spark2.0从入门到精通

年薪50万!人工智能学习路线教程

年薪50万!大数据从入门到精通学习路线年薪50万!机器学习入门到精通视频教程
仿小米商城类app和小程序视频教程深度学习数据分析基础到实战最新黑马javaEE2.1就业课程从 0到JVM实战高手教程 MySQL入门到精通教程
查看: 299|回复: 0

[jsp学习]用Java日志包进行调试

[复制链接]
  • TA的每日心情
    开心
    2021-3-12 23:18
  • 签到天数: 2 天

    [LV.1]初来乍到

    发表于 2014-10-1 03:57:56 | 显示全部楼层 |阅读模式
    java日志包进行调试  

    作者: Builder.com
    Tuesday, April 6 2004 11:23 AM   

         在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");
         }
    }   
      
       
       
       

       
      

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


    C:java>java  tips.LogTip
    2005-6-30 14:07:23 tips.LogTip main
    信息: a little bit of information
    2005-6-30 14:07:23 tips.LogTip main
    警告: a warning message
    2005-6-30 14:07:23 tips.LogTip main
    严重: a severe message

    C:java>

          并不是所有的记录项都会显示在控制台中,这是因为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  

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

    C:java>java -Djava.util.logging.config.file=log.properties tips.LogTip
    2005-6-30 14:10:13 tips.LogTip main
    最好: the finest message
    2005-6-30 14:10:13 tips.LogTip main
    较好: finer message
    2005-6-30 14:10:13 tips.LogTip main
    良好: a fine message
    2005-6-30 14:10:13 tips.LogTip main
    配置: some configuration message
    2005-6-30 14:10:13 tips.LogTip main
    信息: a little bit of information
    2005-6-30 14:10:13 tips.LogTip main
    警告: a warning message
    2005-6-30 14:10:13 tips.LogTip main
    严重: a severe message

    C:java>

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

      

      
      
       
       

         
       

         
       
      

       

      

      



                            function TempSave(ElementID)
                            {
                                    CommentsPersistDiv.setAttribute("CommentContent",document.getElementById(ElementID).value);
                                    CommentsPersistDiv.save("CommentXMLStore");
                            }
                            function Restore(ElementID)
                            {
                                    CommentsPersistDiv.load("CommentXMLStore");
                                    document.getElementById(ElementID).value=CommentsPersistDiv.getAttribute("CommentContent");
                            }
                   
                      











    源码下载:http://file.javaxxz.com/2014/10/1/035756141.zip
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    QQ|手机版|Java学习者论坛 ( 声明:本站资料整理自互联网,用于Java学习者交流学习使用,对资料版权不负任何法律责任,若有侵权请及时联系客服屏蔽删除 )

    GMT+8, 2024-5-2 06:59 , Processed in 0.403421 second(s), 48 queries .

    Powered by Discuz! X3.4

    © 2001-2017 Comsenz Inc.

    快速回复 返回顶部 返回列表