Difference between printStackTrace() and toString()

后端 未结 7 1396
甜味超标
甜味超标 2020-12-08 02:06

I\'m curious as to what the difference is between printStackTrace() and toString(). At first sight, they seem to do the exact same thing.

Code:

相关标签:
7条回答
  • 2020-12-08 02:27

    No, there is an important difference! Using toString, you only have the type of the exception and the error message. Using printStackTrace() you get the whole stacktrace of an exception, which is very helpful for debugging.

    Example of System.out.println(toString()):

    java.io.FileNotFoundException: yourFile.txt (The system cannot find the file specified)
    

    Example of 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)
    

    To make a string of the whole stacktrace, I usually use this method:

    public static String exceptionStacktraceToString(Exception e)
    {
        ByteArrayOutputStream baos = new ByteArrayOutputStream();
        PrintStream ps = new PrintStream(baos);
        e.printStackTrace(ps);
        ps.close();
        return baos.toString();
    }
    

    Also note that simply calling toString() simply returns a string, and won't print anything out.

    0 讨论(0)
提交回复
热议问题