ref:http://blog.mayongfa.cn/267.html

阿里巴巴 Java 开发手册

前几天阿里巴巴在云栖社区首次公开阿里官方Java代码规范标准,就是一个PDF手册,有命名规范,让你知道自己原来取的每一个类名、变量名都是烂名字,真替你家未来孩子担心;有集合处理、并发处理、OOM/NPE 异常、魔法值等等好多规范,什么?你不知道什么是魔法值,算了,我也是第一次听说:即未经定义的常量;还有一个关于 Map 遍历的推荐,这个大家应该都知道,推荐使用 entrySet 遍历 Map 类集合 KV,而不是 keySet 方式进行遍历。 因为 keySet 是遍历了 2 次,而 entrySet 只是遍历了一次就把 key 和 value 都放到了 entry 中,效率更高。还有接口类中的方法和属性不要加任何修饰符号(public 也不要加)这些推荐做法,这些都没什么,日常开发中应该做到的规范,但下面这个【强制】,我发现我接触的项目都没做到。

【强制】应用中不可直接使用日志系统(Log4j、Logback)中的 API

在手册中的日志规约中,看到有一条这样的规定,说实话我有点懵逼, Log4j 不是 Java 中应用最广的日志系统么?为啥不让用?

【强制】应用中不可直接使用日志系统(Log4j、Logback)中的API,而应依赖使用日志框架SLF4J中的API,使用门面模式的日志框架,有利于维护和各个类的日志处理方式统一。
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
private static final Logger logger = LoggerFactory.getLogger(Abc.class);

在这段规约中看到了推荐使用 SLF4J 这个日志框架,而且还是毫不由分说的【强制】,那它到底好在什么地方?

SLF4J,即简单日志门面(Simple Logging Facade for Java),不是具体的日志解决方案,它只服务于各种各样的日志系统。按照官方的说法,SLF4J是一个用于日志系统的简单Facade,允许最终用户在部署其应用时使用其所希望的日志系统。来自百科里的描述

大概意思就是说 SLF4J 是一个日志抽象层,允许你使用任何一个日志系统,并且可以随时切换还不需要动到已经写好的程序(我特么是真改过整个项目的所有打印日志的代码,累死...),这对于第三方组件的引入的不同日志系统来说几乎零学习成本了,况且它的优点不仅仅这一个而已,还有简洁的占位符的使用和日志级别的判断,众所周知的日志读写一定会影响系统的性能,但这些特性都是对系统性能友好的。官网地址:https://www.slf4j.org/

少废话,你来测试一下

说了辣么多,下面我就将建立一个项目,是 Maven 项目哦,并用 SLF4J 来结合 JDK14、Simple、Logback、Log4j做日志系统,在上述几个日志系统间随意切换,而且不修改一行代码,甚至不用修改一个字符。

1.首先建立一个简单的 Java 项目(Maven Project),目录结构如下:

2.在 pom.xml 中增加 SLF4J API 依赖包
使用的目前最新稳定版 1.7.22 的 SLF4J:

  1. <dependency>
  2. <groupId>org.slf4j</groupId>
  3. <artifactId>slf4j-api</artifactId>
  4. <version>1.7.22</version>
  5. </dependency>

jar 包: slf4j-api-1.7.22.jar
接着并在测试项目中的 App.java 中加入日志输出代码,代码如下:

  1. package xyz.mafly.SLF4JTest;
  2. import org.slf4j.Logger;
  3. import org.slf4j.LoggerFactory;
  4. /**
  5. * Hello world!
  6. *
  7. */
  8. public class App {
  9. final Logger logger = LoggerFactory.getLogger(App.class);
  10. private void test() {
  11. logger.info("这是一条日志信息 - {}", "mafly");
  12. }
  13. public static void main(String[] args) {
  14. App app = new App();
  15. app.test();
  16. System.out.println("Hello World!");
  17. }
  18. }

到这里,代码就写完了、写完了。以后无论在 Log4j 还是 Logback 日志系统切换,都不需要修改这里的代码!一个字符都不需要!!

3. JDK14 日志系统,slf4j-jdk14
pom.xml 中增加 slf4j-jdk14 依赖包:

  1. <dependency>
  2. <groupId>org.slf4j</groupId>
  3. <artifactId>slf4j-jdk14</artifactId>
  4. <version>1.7.22</version>
  5. </dependency>

jar 包: slf4j-jdk14-1.7.22.jar
运行程序,即可看到如下图输出:

4. Simple 日志系统,slf4j-simple
在 pom.xml 中注释掉 JDK14 包节点,增加 slf4j-simple 依赖包:

  1. <dependency>
  2. <groupId>org.slf4j</groupId>
  3. <artifactId>slf4j-simple</artifactId>
  4. <version>1.7.22</version>
  5. </dependency>

jar 包: slf4j-simple-1.7.22.jar
运行程序,即可看到如下图不同输出:

5. Log4j 日志系统(最常用), slf4j-log4j
依然是在 pom.xml 中注释掉 Simple 包节点,增加 slf4j-log4j12 依赖包:

  1. <dependency>
  2. <groupId>org.slf4j</groupId>
  3. <artifactId>slf4j-log4j12</artifactId>
  4. <version>1.7.22</version>
  5. </dependency>

jar 包: slf4j-log4j12-1.7.22.jar、 log4j-1.2.17.jar

Log4j 除了导入 jar 包后,还需要增加一下日志格式的配置文件,我新增了一个log4j.properties的日志配置文件,具体 Log4j 详细配置我之前在 《log4j 项目中的详细配置》 这篇博客中写过。运行程序,即可看到如下图输出(输出格式可自己配置):

6. Logback 日志系统, slf4j-logback
在 pom.xml 中注释掉 Log4j 包节点,增加 slf4j-logback 依赖包:

  1. <dependency>
  2. <groupId>ch.qos.logback</groupId>
  3. <artifactId>logback-core</artifactId>
  4. <version>1.1.9</version>
  5. </dependency>
  6. <dependency>
  7. <groupId>ch.qos.logback</groupId>
  8. <artifactId>logback-classic</artifactId>
  9. <version>1.1.9</version>
  10. </dependency>

jar 包: logback-core-1.1.9.jarlogback-classic-1.1.9.jar
运行程序,也可看到如下图日志输出:

总结一下

看完阿里巴巴的这个开发手册,的确学到了一些新知识和规范,SLF4J 只是其中一个知识点而已。
说回 SLF4J 这个日志框架,在下一个开源项目或内部类库中都强烈推荐使用 SLF4J ,它的好处不言而喻,这也是阿里巴巴强制使用的原因所在。希望这篇文章对你的项目中日志系统有所帮助,任何一个任何编程语言的开发者,都应该重视日志的重要性和编码规范,对你、团队和未来阅读你代码的人都好,相信我,他们肯定会感激你的。

转载于:https://www.cnblogs.com/studyskill/p/9558084.html

ref:下一个项目为什么要用 SLF4J相关推荐

  1. 下一个项目要从开始抓的几件事情

    进入新项目3个月.发现很多地方失控(内存.场景性能).在这里总结下一些半路的经验. 1. 内存监控:必须从一刚开始做,必须从一刚开始追踪到内存的增长.比较好的方式是以登录界面.新手场景.主要场景的出生 ...

  2. spring boo_为您的下一个基于Spring的应用程序考虑使用spring-boot的原因!

    spring boo Spring-boot提供了一种创建基于Spring的应用程序的快速方法. 对于下一个项目,有一些非常令人信服的理由考虑使用Spring-boot: 原因1:使用spring-b ...

  3. 为您的下一个基于Spring的应用程序考虑使用spring-boot的原因!

    Spring-boot提供了一种创建基于Spring的应用程序的快速方法. 对于下一个项目,有一些非常令人信服的理由考虑使用Spring-boot: 原因1:使用spring-boot启动程序项目进行 ...

  4. 开发团队如何完成一个项目?

    最近一直在考虑程序员和团体的关系,那么一个项目怎么该在一个团体中完整的跑下来呢(自己琢磨的,请见谅) 1.确定目标,划分story. 1. 业务和技术单列开来.团体中有业务接口人负责专门和客户沟通,并 ...

  5. javadoc 开源项目_在下一个项目中不使用JavaDoc的5大原因

    javadoc 开源项目 JavaDoc对于框架和库的开发是绝对必需的,这些框架和库为其他框架(例如Spring Framework,JDK)提供了公共接口. 对于内部企业软件和/或产品开发,我有以下 ...

  6. 在下一个项目中不使用JavaDoc的5大原因

    JavaDoc对于框架和库的开发是绝对必要的,这些框架和库为其他框架(例如Spring Framework,JDK)提供了公共接口. 对于内部企业软件和/或产品开发,我有以下原因会在将来忽略" ...

  7. 帮助您快速开始下一个移动APP应用模板、UI设计

    人们离不开智能手机,"移动第一"的设计理念是一个关键,而移动软件的用户体验每年都在显著改善. 应用模板可以帮助您快速开始下一个移动应用模型.UI设计或实现.该特性将帮助您找到适合您 ...

  8. 谁会是下一个ASO优化的“优等生” 怎么做aso优化

    想当年喜马拉雅FM号称"牛皮癣"是何等的风骚,独霸APP江湖数年,但那些都是过去式了.现在是ASO"优等生"的天下,放眼看去一个又一个的ASO"优等生 ...

  9. web密码尝试工具_尝试下一个Web项目的10种工具

    web密码尝试工具 接下来是一些工具的组合,您作为开发人员或设计人员可以尝试下一个项目. 该列表绝不是详尽无遗的,也不是任何事物的"前十名",而只是对那些寻求新事物的人的建议. 我 ...

最新文章

  1. unittest 出报告 并配合 jenkins,发现有用例错误,但是构建没出现红点 的解决方法
  2. IBM AI辩手对战世界级人类辩手,炒作还是秀肌肉?
  3. 2016年我国研究的超级计算机,盘点2016:我国科研取得的重大成果
  4. Hadoop学习--Hive安装与配置
  5. VSC为_计及功率控制模式的VSC-MTDC交直流并列运行系统概率潮流计算
  6. php为什么获取不到id,微信小程序无法获取到unionId怎么办
  7. mysql使用手册_mysql使用手册
  8. 怎样用mysql查询测试_如何测试数据库查询优化器
  9. python excel 单元格格式_python设置单元格数值格式
  10. 析构函数c+_了解C ++中的析构函数
  11. 改2字节将Win XP Home变成Pro?!(zz)
  12. 使用TF卡烧录Jetson NX开发板
  13. 人工智能学习思维导图
  14. 卷积编码verilog实现
  15. Web 应用防火墙:Modsecurity 和核心规则集
  16. Postgresql 之 数据库认证
  17. 【亲测已解决】CentOS7 ifconfig commend not fount(命令找不到)
  18. 【Vuex】模仿京东购物车,用Vuex实现一个购物车功能
  19. OC--Foundation--数组
  20. 操作系统bootloader是什么

热门文章

  1. 程序员都怎么过端午节?
  2. EF 实现自定义数据库字符串
  3. linux内核开发基础(linux内核源码、树莓派源码编译、SD卡挂载)
  4. 将c程序移植到linux,各位大侠:我把原来在linux运行的c程序移植到HPUNIX上出现了错误...
  5. ui设计师常用的设计工具_2020年应该使用哪个UI设计工具?
  6. 设计模式练习_设计练习是邪恶的
  7. Web:你知道我这十几年是怎么过来的吗?!
  8. 刚被IBM收购的红帽,它的下一站是中国
  9. solidity字符串拼接
  10. 多语言报表的改动方法