当前位置: 首页 > news >正文

中国水电建设招标网站科技型中小企业服务网

中国水电建设招标网站,科技型中小企业服务网,广州外贸网络推广,网站设计制作视频【0】README 0.1#xff09; 本文描述源代码均 转自 core java volume 1#xff0c; 旨在理解 java日志——基本日志高级日志 的相关知识#xff1b; 【1】记录日志 1.1#xff09;出现的问题和解决方法#xff1a; 1.1.1#xff09;出现的问题#xff1a;在我们调试…【0】README 0.1 本文描述源代码均 转自 core java volume 1 旨在理解 java日志——基本日志高级日志 的相关知识 【1】记录日志 1.1出现的问题和解决方法 1.1.1出现的问题在我们调试的时候 通过喜欢 插入 System.out.println 语句来辅助我们调试 当出现新的问题又要插入 该语句进行调试。 1.1.2解决方法记录日志API 就是为了解决这个问题而设计的。 1.2下面是记录日志 API的优点Priority P1可以很容易地取消全部日志记录 或者仅仅取消某个级别的日志 而且打开和关闭这个操作也很容易P2可以很简单地禁止日志记录的输出 因此将这些日志代码留在程序中的开销很小P3日志记录可以被定向到不同的处理器 用于在控制台中显示 用于存储在文件中等P4日志记录器和处理器都可以对记录进行过滤。 过滤器可以根据过滤实现器制定的标准丢弃那些无用的记录项P5日志记录可以采用不同的方式格式化例如 纯文本或 xmlP6应用程序可以使用 多个 日志记录器 他们使用类似包名的这种具有层次结构的名字 如 com.a.b.c; P7在默认情况下 日志系统的配置由配置文件控制。 如果需要的话 应用程序可以替换这个配置 【2】基本日志 2.1看个荔枝日志系统管理者一个名为 Logger.global 的默认日志记录器 可以用System.out 替换他 并通过调用 info 方法记录日志信息 Logger.getGlobal().info(File-Open menu item seleted); 2.1.1在默认情况下这条记录将会显示如下内容 May 10, 2013 10:12:25 PM LoggingImageView fileOpen INFO: FIle-Open menu item selected Attention A1自动包含了 时间、调用的类名和方法名A2 如果在相应的地方调用 Logger.getGlobal().setLevel(Level.OFF)将会取消所有日志 Warning在修改bug 7184195 前还需要调用 Logger.getGlobal().setLevel(Level.INFO)来激活全局日志记录器 【3】高级日志 3.1在一个专业的应用程序中 不要将所有的日志都记录到 一个全局日志记录器中 而是可以自定义日志记录器; * 3.1.1调用 getLogger方法可以创建或 检索记录器 private static final Logger myLogger Logger.getLogger(com.mycompany.myapp); 3.2与包名类似 日志记录器名也具有层次结构且层次性更强 3.2.1对于包来说 一个包的名字与其父包的名字间没有语义关系 但是日志记录器的父与子间将共享某些属性3.2.2看个荔枝 如果对 com.mycompany 日志记录器设置了 日志级别 它的子记录器也会继承这个级别 通常有7个日志记录器级别Level L1 SEVEREL2 WARNINGL3 INFOL4 CONFIGL5 FINEL6 FINERL7 FINEST3.2.3默认情况下 只记录前3个级别 也可以设置其他级别 logger.setLevel(Level.FINE); 3.2.4使用 Level.ALL 开启所有级别的记录 使用 Level.OFF 关闭所有级别的记录 3.3对于所有的基本有下面几种记录方法Methods M1 logger.warning(msg);M2 logger.fine(msg);M3使用log 方法指定级别 logger.log(Lebel.FINE, msg) Hint默认的日志配置记录了 INFO 或更高级别的所有记录 因此应该使用 CONFIG、FINE, FINER, FINEST 级别来记录那些有助于诊断 但对于程序员有没有太大意义的调试信息 Warning如果将记录设计为INFO 或更低 则需要修改日志处理器的配置 默认的日志处理器不会处理低于 INFO 级别的信息 3.4默认的日志记录将显示包含日志调用的类名和方法名 如同堆栈所显示的那样。 但是 如果虚拟机对执行过程进行了优化 就得不到准确的调用信息。 此时 可以调用 logp 方法获得调用类和方法的确切位置 这个方法的签名为 void logp(level l , String className, String methodName, String msg) 3.4.1下面有一些跟踪执行流的方法 void entering(String className, String methodName) void entering(String className, String methodName, Object param) void entering(String className, String methodName, Object[] params) void entering(String className, String methodName) void entering(String className, String methodName, Object result) 3.4.2看个荔枝 int read(Strinf file, String pattern) {logger.entering(com.mycompany.mylib.Reader, read, new Object[] {file, pattern});......logger.exiting(com.mycompany.mylib.Reader, read, count);return count; } 这些调用将生成FINER 级别和以 字符串“ENTRY” 和 “RETURN”开始的日志记录 3.5记录日志的常见用途是记录那些不可预料的异常。 可以使用下面两个方法提供日志记录中包含的异常描述内容Methods 日志记录 API 如下 void throwing(String className, String methodName, Throwable t) void log(Level l , String msg, Throwable t) M1典型用法是 if(...) {IOException exception new IOException();logger.throwing(com.mycompany.mylib.Reader, read, exception);throw exception; } M2还有一种 try {... } catch(Exception e) {Logger.getLogger(com.mycompany.myapp).log(Level.WARNING, Reading image, e); } 调用throwing 可以记录一条 FINER 级别的记录和一条以 THROW 开始的信息
http://www.zqtcl.cn/news/620875/

相关文章:

  • 做网站树立品牌形象建设了网站后怎么用谷歌引流
  • 专业公司网站建设建设人才库网站
  • 怎么自己做直播网站吗手机免费建站app
  • 惠州规划建设局网站seo网站关键词排名优化公司
  • 关键词检测百度seo一本通
  • 做效果图的外包网站徐州低价seo
  • xp系统中做网站服务器吗网站设计版权
  • 化妆品网站建设经济可行性分析怎么做好网站
  • 软件企业网站建设栏目结构图服务公司有哪些
  • 郑州专业做淘宝网站推广哪些公司需要网站开发工程师
  • 如何为企业做网站单页网站推广
  • 做公众号封面图的网站凡客精选app
  • 张家界做旅游网站网业小说畅读服务
  • 短租网站那家做的好网络设计工作好找吗
  • 企业建网站哪家好网络书签 wordpress
  • 网站策划的工作职责有关网站开发的创意
  • 上国外网站dns如何免费做网站推广
  • wordpress导航站的源码网页设计与制作微课教程第4版李敏
  • 建站的好公司wordpress 小工具 调用
  • 郑州高考网站建设wordpress调用多个底部
  • 在线做爰直播网站dw制作网页步骤
  • 视频网站 php源码深圳高端网站建设招聘
  • 企业网站服务费怎么做记账凭证那个网站上有打码的任务做
  • 沈阳做网站优化的公司长春网络建站模板
  • 秒收网站鞍山58同城
  • 模板网站建设方案wordpress系统在线升级
  • 男女做爰视频网站在线视频seo也成搜索引擎优化
  • 网站优化和网站推广深圳市高端网站建设
  • 宁波网站建设优化企业推荐四川省建设厅新网站
  • 哈尔滨模板自助建站优秀的电子商务网站