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

做公司英文网站网站建设与维护工作

做公司英文网站,网站建设与维护工作,王烨峰,网站建设中的图片及视频要求目录 一. 打印日志的常见三种方法? 1.1 手动创建 Logger 对象(基于SLF4J API) 1.2 使用 Lombok 插件的 Slf4j 注解 1.3 使用 Spring 的 Log 接口(使用频率较低) 二. 常见的 Logger,logger,…

目录

一. 打印日志的常见三种方法?

1.1 手动创建 Logger 对象(基于SLF4J API)

1.2 使用 Lombok 插件的 @Slf4j 注解

1.3 使用 Spring 的 Log 接口(使用频率较低)

二. 常见的 Logger,logger,log是有什么关系吗?

三. 日志的级别和推荐级别


一. 打印日志的常见三种方法?

1.1 手动创建 Logger 对象(基于SLF4J API)

第一种方法就是手动创建 logger 日志对象,直接通过 LoggerFactory 日志工厂创建即可,使用 Logger 类型来接收,这里实例对象就叫 "logger"。

SLF4J 是日志门面(Facade),它提供统一的日志接口,不直接实现日志功能。

核心类org.slf4j.Logger 是 SLF4J 的核心接口,通过 LoggerFactory.getLogger() 创建实例。

打印日志也可以单个或多个参数,具体实例如下图,

注意每个"{}"对应一个参数即可,并且参数顺序要对的上。

import com.markerhub.entity.User;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;import java.time.LocalDateTime;public class MyClass {// 通过 LoggerFactory 日志工厂创建日志对象private static final Logger logger = LoggerFactory.getLogger(MyClass.class);public static void main(String[] args) {// 用法一:单个参数 logger 日志打印String message = "abcde";logger.info("这是手动创建的 logger 对象打出的日志:打印单个参数{}", message);// 用法二:多个参数 logger 日志打印int number = 100;String message2 = "abcdefg";long time = 1000000000000000000L;logger.info("这是手动创建的 logger 对象打出的日志:打印多个参数{},{},{}", number, message2, time);// 用法三:对象参数 logger 日志打印User user1 = new User();user1.setUsername("zhangsna");user1.setPassword("123456");user1.setCreated(LocalDateTime.now());user1.setEmail("123456@qq.com");user1.setStatus(1);logger.info("这是手动创建的 logger 对象打出的日志:打印对象参数{}", user1);logger.debug("debug 日志");logger.error("error 日志");}
}

运行程序,如下控制台打印所示,可以看出 info 就是普通的日志,debug 是调试日志,error 是错误日志。

这里之所以有颜色区分是因为小编使用了插件,插件名称:"Grep Console",有需要的小伙伴可以搜索看下使用教程。

1.2 使用 Lombok 插件的 @Slf4j 注解

第二种方法最简单,直接使用 @Slf4j 注解,但需要注意IDEA中需要安装了 Lombok 插件并且你的 spring boot 项目中引用了 lombok 依赖。

@Slf4j 是lombok插件提供的一个注解,用于自动生成 SLF4J 的 Logger 实例,减少样板代码。其底层还是通过第一种方式去新建的 logger 对象。

<dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId>
</dependency>

如下代码

注解在类的头上添加 @Slf4j 注解即可,然后就可以在本类的任意位置直接显式调用 log 对象,不需要再自行创建,非常方便。

import com.markerhub.entity.User;
import lombok.extern.slf4j.Slf4j;import java.time.LocalDateTime;@Slf4j
public class MyClass {public static void main(String[] args) {// 用法一:单个参数 logger 日志打印String message = "abcde";log.info("这是 @Slf4j 注解的 log 对象打出的日志:打印单个参数{}", message);// 用法二:多个参数 logger 日志打印int number = 100;String message2 = "abcdefg";long time = 1000000000000000000L;log.info("这是 @Slf4j 注解的 log 对象打出的日志:打印多个参数{},{},{}", number, message2, time);// 用法三:对象参数 logger 日志打印User user1 = new User();user1.setUsername("zhangsna");user1.setPassword("123456");user1.setCreated(LocalDateTime.now());user1.setEmail("123456@qq.com");user1.setStatus(1);log.info("这是 @Slf4j 注解的 log 对象打出的日志:打印对象参数{}", user1);log.debug("debug 日志");log.error("error 日志");}
}

运行程序,如下图,和上面的 logger 对象效果是完全一样的。 

1.3 使用 Spring 的 Log 接口(使用频率较低)

如下代码所示,Spring 自身提供了 Log接口也可以创建日志对象。

import com.markerhub.entity.User;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import java.time.LocalDateTime;public class MyClass {private static final Log logger = LogFactory.getLog(MyClass.class);public static void main(String[] args) {// 用法一:单个参数 logger 日志打印String message = "abcde";logger.info("这是 @Slf4j 注解的 log 对象打出的日志:打印单个参数{}",message);// 用法二:多个参数 logger 日志打印int number = 100;String message2 = "abcdefg";long time = 1000000000000000000L;logger.info("这是 @Slf4j 注解的 log 对象打出的日志:打印多个参数{},{},{}", number, message2, time);// 用法三:对象参数 logger 日志打印User user1 = new User();user1.setUsername("zhangsna");user1.setPassword("123456");user1.setCreated(LocalDateTime.now());user1.setEmail("123456@qq.com");user1.setStatus(1);logger.info("这是 @Slf4j 注解的 log 对象打出的日志:打印对象参数{}", user1);logger.debug("debug 日志");logger.error("error 日志");}
}

但是, Spring 提供的 logger 对象,无法像前两种一样输出参数值,这一点其实是不太友好的,不过 Spring 提供的这种日志输出方式基本也没人使用,同学们作为了解即可,主要还是前两种用的比较多。

二. 常见的 Logger,logger,log是有什么关系吗?

(1)Logger 是SLF4J提供的日志接口,用于创建日志对象(如 LoggerFactory.getLogger())。需要手动实例化。

(2)log 是通过 @Slf4j 注解生成的变量名,本质还是一个 Logger 实例。

(3)logger ,没有特殊含义,只是采用SLF4J提供的日志接口创建对象时,常常见对象命名为 logger 而已。

三. 日志的级别和推荐级别

如以下表格所示,日志的详细程度由高到低。一般情况下,日志输出的详细,越耗费系统性能,所以不建议将日志输出特别详细,适中即可,大部分都是选择 INFO 级别,也推荐大家尽量选择 INFO 或 DEBUG

级别严重性适用场景生产环境建议开发环境建议
TRACE最低详细追踪程序执行流程关闭按需开启
DEBUG调试代码逻辑和变量状态关闭开启
INFO监控应用运行状态和关键操作开启开启
WARN较高潜在问题,不影响程序运行开启开启
ERROR功能错误,需人工干预开启开启
FATAL最高致命错误,程序无法继续运行开启开启

日志级别的设置,基本在配置文件中设置的,方式如下 

# 设置全局日志级别
logging.level.root=info# 设置特定包的日志级别
logging.level.com.example.myapp=debug# 自定义日志输出格式和文件路径
logging.pattern.console=%d{yyyy-MM-dd HH:mm:ss} [%thread] %-5level %logger{36} - %msg%n
logging.file.name=app.log
http://www.dtcms.com/wzjs/565829.html

相关文章:

  • vue 做自适应网站网址缩短在线生成器
  • 西安营销型网站建设动力无限做网站游戏的网站有哪些
  • 网站开发沟通网络设计思路
  • 免费网站奖励自己游戏网站怎么申请备案
  • 集团公司网站建设品牌建立网站的几个步骤
  • 织梦是怎么做网站吴江开发区人才网
  • 大连企业需要做网站网站源码被注册为商标
  • 北京网站建设yi wl四川旅游攻略
  • 网站开发 工作量评估东莞房价一览表
  • 山西太原建设银行招聘网站怎么自己创建网站或者app
  • 怎么做网站的防盗链已经备案的域名做电影网站
  • 宏基陆通工程建设有限公司网站网站开发需要掌握技术
  • 百度建设网站的目的网页制作基础教程课件葛艳玲
  • 工行网站如何做理财风险评估wordpress cms
  • 网站维护经费哪个网站做正品女装
  • 怎么把做的网站优化到百度企业网站优秀案例
  • 怎样做网站上的语种链接微信小程序制作教学
  • 网站优化推广seowordpress建立网站
  • 做外贸的怎么建立自己的网站深圳 福田网站建设
  • 定制型网站 成功案例建设网站各方面费用预算
  • 外省公司做网站备案建设彩票网站多少钱
  • 珠海高端网站制作公司百度首页网站的设计
  • pc网站优化排名做网站还要写文章吗
  • 做网站和网站页面设计东莞如何制作自己的网站
  • 宠物网站建设总结用网站模板 侵权 做了修改
  • 工厂 电商网站建设重庆环保公司网站建设
  • 网站备案人授权书游学做的好的网站
  • 泰州做网站多少钱做招聘网站的要求
  • 网站生成软件app制作网页代码制作基础教程
  • 申请免费的网站石家庄城乡建设部网站首页