我有很长的异常层次结构,其中一个会在二进制数据中添加长消息。因为它在图书馆,所以我不能在丢失的地方改变它。我如何截断它,而不会丢失另一个异常消息?如何截断java中的长时间异常消息
代码示例:
throw new RuntimeException("msg",
new RuntimeException(generateLongErrorMessage(),
new RuntimeException("short message",
new RuntimeException("important message"))
)
);
所需的输出:
Exception in thread "main" java.lang.RuntimeException: msg
at xxx.excpetionMessageTruncator(Erofeev.java:18)
at xxx.main(Erofeev.java:14)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:606)
at com.intellij.rt.execution.application.AppMain.main(AppMain.java:120)
Caused by: java.lang.RuntimeException: long message long message ...(truncated, original size: 100)
... 7 more
Caused by: java.lang.RuntimeException: short message
... 7 more
Caused by: java.lang.RuntimeException: important message
... 7 more
你在哪里发现这个异常? – radai
@radai,在我的血腥企业项目 –
我的目标是非常像mbred下面说的 - 如果你知道它捕获的代码位置,你可以重建异常并去掉长信息,只是“剥离”外部层和留下根本原因。你唯一的选择是自定义记录器/ appender – radai