• JCL 学习


    全称为Jakarta Commons Logging,是Apache提供的一个通用日志API。

            它是为 "所有的Java日志实现"提供一个统一的接口,它自身也提供一个日志的实现,但是功能非常常弱(SimpleLog)。所以一般不会单独使用它。他允许开发人员使用不同的具体日志实现工具: Log4j, Jdk自带的日志(JUL)

    JCL 有两个基本的抽象类:Log(基本记录器)和LogFactory(负责创建Log实例)。

    1、JCL入门 

    • 建立maven工程
    • 添加依赖
      1. <dependency>
      2. <groupId>commons-logginggroupId>
      3. <artifactId>commons-loggingartifactId>
      4. <version>1.2version>
      5. dependency>
    • 入门代码
      1. public class JCLTest {
      2. @Test
      3. public void testQuick() throws Exception {
      4. // 获取log日志记录器对象
      5. Log log = LogFactory.getLog(JCLTest.class);
      6. // 日志记录的输出
      7. log.info("hello info");
      8. }
      9. }

    我们为什么要使用日志门面:

    1. 面向接口开发,不再依赖具体的实现类。减少代码的耦合
    2. 项目通过导入不同的日志实现类,可以灵活的切换日志框架
    3. 统一API,方便开发者学习和使用
    4. 统一配置便于项目日志的管理

    2、JCL原理

    1. 通过LogFactory动态加载Log实现类

    2. 日志门面支持的日志实现数组 

    1. private static final String[] classesToDiscover =
    2. new String[]{"org.apache.commons.logging.impl.Log4JLogger",
    3. "org.apache.commons.logging.impl.Jdk14Logger",
    4. "org.apache.commons.logging.impl.Jdk13LumberjackLogger",
    5. "org.apache.commons.logging.impl.SimpleLog"};

    3. 获取具体的日志实现

    1. for(int i = 0; i < classesToDiscover.length && result == null; ++i) {
    2. result = this.createLogFromClass(classesToDiscover[i], logCategory,true);
    3. }
  • 相关阅读:
    vulnhub靶场之BLUESMOKE: DEVRANDOM2|bluesmoke
    golang 版本升级
    #前端#scss学习
    生存资料校准曲线calibration curve的绘制
    linux系统编程专题(五) 系统调用之文件IO
    Spring ,Spring MVC,Spring Boot
    基础 | NIO - [IO 发展]
    H3C IPSec IKE野蛮模式
    HTML & CSS
    基于springboot的学生毕业选题管理系统
  • 原文地址:https://blog.csdn.net/weixin_52851967/article/details/126067595