当我使用命令 java ExceptionTest 运行一些java程序时,有时会省略异常,看起来像
Exception in thread "main" java.lang.NoClassDefFoundError: aa/bb/DD
at SOMEWHERE(unknown source)
Caused by: java.lang.ClassNotFoundException: aaa.bbb.CC
at SOMEWHER(unknown source)
... 13 more
在这种情况下,我希望看到另外13个例外。是否有选项可以查看所有异常日志?
答案 0 :(得分:20)
你已经看到了它们,它只是荒谬的方式,Java(和默认的Logback)默认打印异常。这个堆栈跟踪:
Exception in thread "main" java.lang.NoClassDefFoundError: aa/bb/DD
at SOMEWHERE(unknown source)
Caused by: java.lang.ClassNotFoundException: aaa.bbb.CC
at SOMEWHER(unknown source)
... 13 more
实际上意味着以下程序流程(从下到上):
Caused by: java.lang.ClassNotFoundException: aaa.bbb.CC
at SOMEWHER(unknown source)
Exception in thread "main" java.lang.NoClassDefFoundError: aa/bb/DD
at SOMEWHERE(unknown source)
... 13 more
(Logback中的N common frames omitted
)仅表示之前已打印过这些例外。在Logback中,您可以重新构建堆栈跟踪以避免重复,并始终以正确的顺序打印堆栈行,请参阅my blog。
答案 1 :(得分:4)
还有13个例外。调用堆栈还有13行与之前的调用堆栈相同,如下所述:http://java.sun.com/j2se/1.5.0/docs/api/java/lang/Throwable.html#printStackTrace()