В основном, когда это - четко определенное, фиксированное множество значений, которые известны во время компиляции.
можно использовать перечисление в качестве набора очень легко (с EnumSet), и он позволяет Вам определять поведение, ссылаться на элементы по имени, включать их и т.д.
Я закончил свой собственный (я взял реализацию 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();
}
}
Я предлагаю вам использовать класс ExceptionUtils из Apache Commons lang, который предоставляет для этого полезный метод.
Да, вы можете использовать класс StackTraceElement, возвращаемый Throwable.getStackTrace (), и найти подробную информацию.
Из API:
Последний элемент массива (предполагая длину массива является ненулевое значение) представляет нижнюю часть стека, которая является первым методом вызов в последовательности.