java - 如何记录格式化消息、对象数组、异常?

标签 java exception logging slf4j

记录填充消息和异常堆栈跟踪的正确方法是什么?

logger.error(
    "\ncontext info one two three: {} {} {}\n",
    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。

最佳答案

从 SLF4J 1.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 等)以及底层框架的配置方式。但是,如果最后一个参数是异常,则无论底层框架如何,它都会被解释为异常。

关于java - 如何记录格式化消息、对象数组、异常?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6371638/

相关文章:

java - 如何仅传递常见对象的第三个列表?

java - 存储和检索 ParseUsers 列表

c++ - C++ 中的函数范围异常处理——这是一种糟糕的风格吗?

exception - 派生自异常类警告 : CA2237: Mark ISerializable types with SerializableAttribute

javascript - 编写 javascript 时要记录的最有用的内容是什么

java - 如何检查字体是否可嵌入

java - Java 5 中的线程安全 XML 验证

java - 线程 "main"java.util.NoSuchElementException 中的异常 - 无 close()

json - 如何使用 Kusto 解析字符串内的嵌套 JSON

python - logservice.fetch() 不返回任何内容