How to log formatted message, object array, exception?(如何记录格式化消息、对象数组、异常?)
                            本文介绍了如何记录格式化消息、对象数组、异常?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
                        
                        问题描述
记录异常的填充消息和堆栈跟踪的正确方法是什么?
logger.error(
    "
context info one two three: {} {} {}
",
    new Object[] {"1", "2", "3"},
    new Exception("something went wrong"));
我想生成类似以下内容的输出:
context info one two three: 1 2 3
java.lang.Exception: something went wrong
stacktrace 0
stacktrace 1
stacktrace ...
我的SLF4J版本是1.6.1。
推荐答案
从SLF4J1.6.0开始,如果存在多个参数,并且日志记录语句中的最后一个参数是异常,则SLF4J将假定用户希望将最后一个参数视为异常,而不是简单的参数。另请参阅relevant FAQ entry。
因此,编写(SLF4J版本1.7.x和更高版本)
 logger.error("one two three: {} {} {}", "a", "b", 
              "c", new Exception("something went wrong"));
或编写(SLF4J版本1.6.x)
 logger.error("one two three: {} {} {}", new Object[] {"a", "b", 
              "c", new Exception("something went wrong")});
将产生
one two three: a b c
java.lang.Exception: something went wrong
    at Example.main(Example.java:13)
    at java.lang.reflect.Method.invoke(Method.java:597)
    at ...
确切的输出将取决于底层框架(例如Logback、log4j等)以及底层框架的配置方式。但是,如果最后一个参数是异常,则无论基础框架如何,它都将被解释为异常。
                        这篇关于如何记录格式化消息、对象数组、异常?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
				 沃梦达教程
				
			本文标题为:如何记录格式化消息、对象数组、异常?
				
        
 
            
        
             猜你喜欢
        
	     - 如何指定 CORS 的响应标头? 2022-01-01
 - 转换 ldap 日期 2022-01-01
 - java.lang.IllegalStateException:Bean 名称“类别"的 BindingResult 和普通目标对象都不能用作请求属性 2022-01-01
 - 如何使 JFrame 背景和 JPanel 透明且仅显示图像 2022-01-01
 - 未找到/usr/local/lib 中的库 2022-01-01
 - Eclipse 的最佳 XML 编辑器 2022-01-01
 - 获取数字的最后一位 2022-01-01
 - 在 Java 中,如何将 String 转换为 char 或将 char 转换 2022-01-01
 - 将 Java Swing 桌面应用程序国际化的最佳实践是什么? 2022-01-01
 - GC_FOR_ALLOC 是否更“严重"?在调查内存使用情况时? 2022-01-01
 
						
						
						
						
						
				
				
				
				