我很好奇printStackTrace()和toString()之间有什么区别。乍一看,他们似乎是在做同样的事情。
代码:
try {
// Some code
} catch (Exception e)
e.printStackTrace();
// OR
e.toString()
}发布于 2012-04-12 09:16:26
不,有一个重要的区别!使用toString,您只具有异常的类型和错误消息。使用printStackTrace()可以获得异常的整个堆栈跟踪,这对于调试非常有帮助。
System.out.println(toString())示例:
java.io.FileNotFoundException: yourFile.txt (The system cannot find the file specified)printStackTrace()示例:
java.io.FileNotFoundException: yourFile.txt (The system cannot find the file specified)
at java.io.FileInputStream.open(Native Method)
at java.io.FileInputStream.(FileInputStream.java:106)
at java.io.FileReader.(FileReader.java:55)
at ReadFromFile.main(ReadFromFile.java:14)要生成整个堆栈跟踪的字符串,我通常使用以下方法:
public static String exceptionStacktraceToString(Exception e)
{
ByteArrayOutputStream baos = new ByteArrayOutputStream();
PrintStream ps = new PrintStream(baos);
e.printStackTrace(ps);
ps.close();
return baos.toString();
}还要注意的是,简单地调用toString()只会返回一个字符串,不会输出任何内容。
发布于 2012-04-13 08:24:14
要将StackTrace转换为字符串,我使用的更短的实现如下:
public static String exceptionStacktraceToString(Exception e)
{
return Arrays.toString(e.getStackTrace());
}发布于 2012-04-12 09:17:49
不,有很大的不同。如果你只调用toString,它不会打印任何东西-它只会返回一个字符串。e.toString();的catch块是无用的。(正如Martijn指出的,还有堆栈跟踪的问题。)
但就我个人而言,我不会使用这两种方法--我会使用一个日志库(log4j、java.util.logging等),它将Throwable本身作为一个参数,并对其进行有效的格式化--包括可能被截断的堆栈跟踪,以避免重复。
https://stackoverflow.com/questions/10120709
复制相似问题