Получение полного строкового отслеживания стека включая внутреннее исключение

В основном, когда это - четко определенное, фиксированное множество значений, которые известны во время компиляции.

можно использовать перечисление в качестве набора очень легко (с EnumSet), и он позволяет Вам определять поведение, ссылаться на элементы по имени, включать их и т.д.

12
задан ripper234 18 August 2009 в 00:53
поделиться

3 ответа

Я закончил свой собственный (я взял реализацию Throwable.printStackTrace () и немного изменил ее):

public static String joinStackTrace(Throwable e) {
    StringWriter writer = null;
    try {
        writer = new StringWriter();
        joinStackTrace(e, writer);
        return writer.toString();
    }
    finally {
        if (writer != null)
            try {
                writer.close();
            } catch (IOException e1) {
                // ignore
            }
    }
}

public static void joinStackTrace(Throwable e, StringWriter writer) {
    PrintWriter printer = null;
    try {
        printer = new PrintWriter(writer);

        while (e != null) {

            printer.println(e);
            StackTraceElement[] trace = e.getStackTrace();
            for (int i = 0; i < trace.length; i++)
                printer.println("\tat " + trace[i]);

            e = e.getCause();
            if (e != null)
                printer.println("Caused by:\r\n");
        }
    }
    finally {
        if (printer != null)
            printer.close();
    }
}
8
ответ дан 26 October 2019 в 10:45
поделиться

Я предлагаю вам использовать класс ExceptionUtils из Apache Commons lang, который предоставляет для этого полезный метод.

9
ответ дан 26 October 2019 в 10:45
поделиться

Да, вы можете использовать класс StackTraceElement, возвращаемый Throwable.getStackTrace (), и найти подробную информацию.

Из API:

Последний элемент массива (предполагая длину массива является ненулевое значение) представляет нижнюю часть стека, которая является первым методом вызов в последовательности.

2
ответ дан 26 October 2019 в 10:45
поделиться
Другие вопросы по тегам:

Похожие вопросы: