public class ExceptionUtils
extends java.lang.Object
Throwable objects.| Constructor and Description | 
|---|
| ExceptionUtils()Deprecated. 
 Will be private in 3.0. | 
| Modifier and Type | Method and Description | 
|---|---|
| static void | forEach(java.lang.Throwable throwable,
       java.util.function.Consumer<java.lang.Throwable> consumer)Performs an action for each Throwable causes of the given Throwable. | 
| static java.lang.Throwable | getCause(java.lang.Throwable throwable)Deprecated. 
 This feature will be removed in Lang 4, use  Throwable.getCause()instead | 
| static java.lang.Throwable | getCause(java.lang.Throwable throwable,
        java.lang.String[] methodNames)Deprecated. 
 This feature will be removed in Lang 4, use  Throwable.getCause()instead | 
| static java.lang.String[] | getDefaultCauseMethodNames()Deprecated. 
 This feature will be removed in Lang 4 | 
| static java.lang.String | getMessage(java.lang.Throwable th)Gets a short message summarizing the exception. | 
| static java.lang.Throwable | getRootCause(java.lang.Throwable throwable)Introspects the  Throwableto obtain the root cause. | 
| static java.lang.String | getRootCauseMessage(java.lang.Throwable throwable)Gets a short message summarizing the root cause exception. | 
| static java.lang.String[] | getRootCauseStackTrace(java.lang.Throwable throwable)Gets a compact stack trace for the root cause of the supplied
  Throwable. | 
| static java.util.List<java.lang.String> | getRootCauseStackTraceList(java.lang.Throwable throwable)Gets a compact stack trace for the root cause of the supplied  Throwable. | 
| static java.lang.String[] | getStackFrames(java.lang.Throwable throwable)Gets the stack trace associated with the specified
  Throwableobject, decomposing it into a list of
 stack frames. | 
| static java.lang.String | getStackTrace(java.lang.Throwable throwable)Gets the stack trace from a Throwable as a String. | 
| static int | getThrowableCount(java.lang.Throwable throwable)Gets a count of the number of  Throwableobjects in the
 exception chain. | 
| static java.util.List<java.lang.Throwable> | getThrowableList(java.lang.Throwable throwable)Gets the list of  Throwableobjects in the
 exception chain. | 
| static java.lang.Throwable[] | getThrowables(java.lang.Throwable throwable)Gets the list of  Throwableobjects in the
 exception chain. | 
| static boolean | hasCause(java.lang.Throwable chain,
        java.lang.Class<? extends java.lang.Throwable> type)Tests if the throwable's causal chain have an immediate or wrapped exception
 of the given type? | 
| static int | indexOfThrowable(java.lang.Throwable throwable,
                java.lang.Class<? extends java.lang.Throwable> clazz)Returns the (zero-based) index of the first  Throwablethat matches the specified class (exactly) in the exception chain. | 
| static int | indexOfThrowable(java.lang.Throwable throwable,
                java.lang.Class<? extends java.lang.Throwable> clazz,
                int fromIndex)Returns the (zero-based) index of the first  Throwablethat matches the specified type in the exception chain from
 a specified index. | 
| static int | indexOfType(java.lang.Throwable throwable,
           java.lang.Class<? extends java.lang.Throwable> type)Returns the (zero-based) index of the first  Throwablethat matches the specified class or subclass in the exception chain. | 
| static int | indexOfType(java.lang.Throwable throwable,
           java.lang.Class<? extends java.lang.Throwable> type,
           int fromIndex)Returns the (zero-based) index of the first  Throwablethat matches the specified type in the exception chain from
 a specified index. | 
| static boolean | isChecked(java.lang.Throwable throwable)Checks if a throwable represents a checked exception | 
| static boolean | isUnchecked(java.lang.Throwable throwable)Checks if a throwable represents an unchecked exception | 
| static void | printRootCauseStackTrace(java.lang.Throwable throwable)Prints a compact stack trace for the root cause of a throwable
 to  System.err. | 
| static void | printRootCauseStackTrace(java.lang.Throwable throwable,
                        java.io.PrintStream printStream)Prints a compact stack trace for the root cause of a throwable. | 
| static void | printRootCauseStackTrace(java.lang.Throwable throwable,
                        java.io.PrintWriter printWriter)Prints a compact stack trace for the root cause of a throwable. | 
| static void | removeCommonFrames(java.util.List<java.lang.String> causeFrames,
                  java.util.List<java.lang.String> wrapperFrames)Removes common frames from the cause trace given the two stack traces. | 
| static <R> R | rethrow(java.lang.Throwable throwable)Throws a checked exception without adding the exception to the throws
 clause of the calling method. | 
| static java.util.stream.Stream<java.lang.Throwable> | stream(java.lang.Throwable throwable)Streams causes of a Throwable. | 
| static <T extends java.lang.Throwable> | throwableOfThrowable(java.lang.Throwable throwable,
                    java.lang.Class<T> clazz)Returns the first  Throwablethat matches the specified class (exactly) in the exception chain. | 
| static <T extends java.lang.Throwable> | throwableOfThrowable(java.lang.Throwable throwable,
                    java.lang.Class<T> clazz,
                    int fromIndex)Returns the first  Throwablethat matches the specified type in the exception chain from
 a specified index. | 
| static <T extends java.lang.Throwable> | throwableOfType(java.lang.Throwable throwable,
               java.lang.Class<T> type)Returns the throwable of the first  Throwablethat matches the specified class or subclass in the exception chain. | 
| static <T extends java.lang.Throwable> | throwableOfType(java.lang.Throwable throwable,
               java.lang.Class<T> type,
               int fromIndex)Returns the first  Throwablethat matches the specified type in the exception chain from
 a specified index. | 
| static <T> T | throwUnchecked(T throwable)Tests whether the cause of the specified  Throwableshould be thrown and does it if necessary. | 
| static <R> R | wrapAndThrow(java.lang.Throwable throwable)Throws a checked exception without adding the exception to the throws
 clause of the calling method. | 
@Deprecated public ExceptionUtils()
ExceptionUtils to be created, although that is not
 normally necessary.public static void forEach(java.lang.Throwable throwable,
                           java.util.function.Consumer<java.lang.Throwable> consumer)
 A throwable without cause will return a stream containing one element - the input throwable. A throwable with one cause
 will return a stream containing two elements. - the input throwable and the cause throwable. A null throwable
 will return a stream of count zero.
 
This method handles recursive cause structures that might otherwise cause infinite loops. The cause chain is processed until the end is reached, or until the next item in the chain is already in the result set.
throwable - The Throwable to traverse.consumer - a non-interfering action to perform on the elements.@Deprecated public static java.lang.Throwable getCause(java.lang.Throwable throwable)
Throwable.getCause() insteadThrowable to obtain the cause.
 The method searches for methods with specific names that return a
 Throwable object. This will pick up most wrapping exceptions,
 including those from JDK 1.4.
 
The default list searched for are:
getCause()getNextException()getTargetException()getException()getSourceException()getRootCause()getCausedByException()getNested()If none of the above is found, returns null.
throwable - the throwable to introspect for a cause, may be nullThrowable,
  null if none found or null throwable input@Deprecated
public static java.lang.Throwable getCause(java.lang.Throwable throwable,
                                                       java.lang.String[] methodNames)
Throwable.getCause() insteadThrowable to obtain the cause.
 A null set of method names means use the default set.
 A null in the set of method names will be ignored.
throwable - the throwable to introspect for a cause, may be nullmethodNames - the method names, null treated as default setThrowable,
  null if none found or null throwable input@Deprecated public static java.lang.String[] getDefaultCauseMethodNames()
This may be modified and used in the overloaded getCause(Throwable, String[]) method.
public static java.lang.String getMessage(java.lang.Throwable th)
The message returned is of the form {ClassNameWithoutPackage}: {ThrowableMessage}
th - the throwable to get a message for, null returns empty stringpublic static java.lang.Throwable getRootCause(java.lang.Throwable throwable)
Throwable to obtain the root cause.
 This method walks through the exception chain to the last element,
 "root" of the tree, using Throwable.getCause(), and
 returns that exception.
From version 2.2, this method handles recursive cause structures that might otherwise cause infinite loops. If the throwable parameter has a cause of itself, then null will be returned. If the throwable parameter cause chain loops, the last element in the chain before the loop is returned.
throwable - the throwable to get the root cause for, may be nullThrowable,
  null if null throwable inputpublic static java.lang.String getRootCauseMessage(java.lang.Throwable throwable)
The message returned is of the form {ClassNameWithoutPackage}: {ThrowableMessage}
throwable - the throwable to get a message for, null returns empty stringpublic static java.lang.String[] getRootCauseStackTrace(java.lang.Throwable throwable)
Throwable.
 The output of this method is consistent across JDK versions. It consists of the root exception followed by each of its wrapping exceptions separated by '[wrapped]'. Note that this is the opposite order to the JDK1.4 display.
throwable - the throwable to examine, may be nullpublic static java.util.List<java.lang.String> getRootCauseStackTraceList(java.lang.Throwable throwable)
Throwable.
 The output of this method is consistent across JDK versions. It consists of the root exception followed by each of its wrapping exceptions separated by '[wrapped]'. Note that this is the opposite order to the JDK1.4 display.
throwable - the throwable to examine, may be nullpublic static java.lang.String[] getStackFrames(java.lang.Throwable throwable)
Throwable object, decomposing it into a list of
 stack frames.
 The result of this method vary by JDK version as this method
 uses Throwable.printStackTrace(java.io.PrintWriter).
 On JDK1.3 and earlier, the cause exception will not be shown
 unless the specified throwable alters printStackTrace.
throwable - the Throwable to examine, may be nullpublic static java.lang.String getStackTrace(java.lang.Throwable throwable)
The result of this method vary by JDK version as this method
 uses Throwable.printStackTrace(java.io.PrintWriter).
 On JDK1.3 and earlier, the cause exception will not be shown
 unless the specified throwable alters printStackTrace.
throwable - the Throwable to be examined, may be nullprintStackTrace(PrintWriter) method, or an empty String if null inputpublic static int getThrowableCount(java.lang.Throwable throwable)
Throwable objects in the
 exception chain.
 A throwable without cause will return 1.
 A throwable with one cause will return 2 and so on.
 A null throwable will return 0.
From version 2.2, this method handles recursive cause structures that might otherwise cause infinite loops. The cause chain is processed until the end is reached, or until the next item in the chain is already in the result set.
throwable - the throwable to inspect, may be nullpublic static java.util.List<java.lang.Throwable> getThrowableList(java.lang.Throwable throwable)
Throwable objects in the
 exception chain.
 A throwable without cause will return a list containing
 one element - the input throwable.
 A throwable with one cause will return a list containing
 two elements. - the input throwable and the cause throwable.
 A null throwable will return a list of size zero.
This method handles recursive cause structures that might otherwise cause infinite loops. The cause chain is processed until the end is reached, or until the next item in the chain is already in the result set.
throwable - the throwable to inspect, may be nullpublic static java.lang.Throwable[] getThrowables(java.lang.Throwable throwable)
Throwable objects in the
 exception chain.
 A throwable without cause will return an array containing
 one element - the input throwable.
 A throwable with one cause will return an array containing
 two elements. - the input throwable and the cause throwable.
 A null throwable will return an array of size zero.
From version 2.2, this method handles recursive cause structures that might otherwise cause infinite loops. The cause chain is processed until the end is reached, or until the next item in the chain is already in the result set.
throwable - the throwable to inspect, may be nullgetThrowableList(Throwable)public static boolean hasCause(java.lang.Throwable chain,
                               java.lang.Class<? extends java.lang.Throwable> type)
chain - The root of a Throwable causal chain.type - The exception type to test.wrapAndThrow(Throwable)public static int indexOfThrowable(java.lang.Throwable throwable,
                                   java.lang.Class<? extends java.lang.Throwable> clazz)
Throwable
 that matches the specified class (exactly) in the exception chain.
 Subclasses of the specified class do not match - see
 indexOfType(Throwable, Class) for the opposite.
 A null throwable returns -1.
 A null type returns -1.
 No match in the chain returns -1.
throwable - the throwable to inspect, may be nullclazz - the class to search for, subclasses do not match, null returns -1public static int indexOfThrowable(java.lang.Throwable throwable,
                                   java.lang.Class<? extends java.lang.Throwable> clazz,
                                   int fromIndex)
Throwable
 that matches the specified type in the exception chain from
 a specified index.
 Subclasses of the specified class do not match - see
 indexOfType(Throwable, Class, int) for the opposite.
 A null throwable returns -1.
 A null type returns -1.
 No match in the chain returns -1.
 A negative start index is treated as zero.
 A start index greater than the number of throwables returns -1.
throwable - the throwable to inspect, may be nullclazz - the class to search for, subclasses do not match, null returns -1fromIndex - the (zero-based) index of the starting position,
  negative treated as zero, larger than chain size returns -1public static int indexOfType(java.lang.Throwable throwable,
                              java.lang.Class<? extends java.lang.Throwable> type)
Throwable
 that matches the specified class or subclass in the exception chain.
 Subclasses of the specified class do match - see
 indexOfThrowable(Throwable, Class) for the opposite.
 A null throwable returns -1.
 A null type returns -1.
 No match in the chain returns -1.
throwable - the throwable to inspect, may be nulltype - the type to search for, subclasses match, null returns -1public static int indexOfType(java.lang.Throwable throwable,
                              java.lang.Class<? extends java.lang.Throwable> type,
                              int fromIndex)
Throwable
 that matches the specified type in the exception chain from
 a specified index.
 Subclasses of the specified class do match - see
 indexOfThrowable(Throwable, Class) for the opposite.
 A null throwable returns -1.
 A null type returns -1.
 No match in the chain returns -1.
 A negative start index is treated as zero.
 A start index greater than the number of throwables returns -1.
throwable - the throwable to inspect, may be nulltype - the type to search for, subclasses match, null returns -1fromIndex - the (zero-based) index of the starting position,
  negative treated as zero, larger than chain size returns -1public static boolean isChecked(java.lang.Throwable throwable)
throwable - The throwable to check.public static boolean isUnchecked(java.lang.Throwable throwable)
throwable - The throwable to check.public static void printRootCauseStackTrace(java.lang.Throwable throwable)
System.err.
 The compact stack trace starts with the root cause and prints stack frames up to the place where it was caught and wrapped. Then it prints the wrapped exception and continues with stack frames until the wrapper exception is caught and wrapped again, etc.
The output of this method is consistent across JDK versions. Note that this is the opposite order to the JDK1.4 display.
The method is equivalent to printStackTrace for throwables
 that don't have nested causes.
throwable - the throwable to outputpublic static void printRootCauseStackTrace(java.lang.Throwable throwable,
                                            java.io.PrintStream printStream)
The compact stack trace starts with the root cause and prints stack frames up to the place where it was caught and wrapped. Then it prints the wrapped exception and continues with stack frames until the wrapper exception is caught and wrapped again, etc.
The output of this method is consistent across JDK versions. Note that this is the opposite order to the JDK1.4 display.
The method is equivalent to printStackTrace for throwables
 that don't have nested causes.
throwable - the throwable to output, may be nullprintStream - the stream to output to, may not be nulljava.lang.NullPointerException - if the printStream is nullpublic static void printRootCauseStackTrace(java.lang.Throwable throwable,
                                            java.io.PrintWriter printWriter)
The compact stack trace starts with the root cause and prints stack frames up to the place where it was caught and wrapped. Then it prints the wrapped exception and continues with stack frames until the wrapper exception is caught and wrapped again, etc.
The output of this method is consistent across JDK versions. Note that this is the opposite order to the JDK1.4 display.
The method is equivalent to printStackTrace for throwables
 that don't have nested causes.
throwable - the throwable to output, may be nullprintWriter - the writer to output to, may not be nulljava.lang.NullPointerException - if the printWriter is nullpublic static void removeCommonFrames(java.util.List<java.lang.String> causeFrames,
                                      java.util.List<java.lang.String> wrapperFrames)
causeFrames - stack trace of a cause throwablewrapperFrames - stack trace of a wrapper throwablejava.lang.NullPointerException - if either argument is nullpublic static <R> R rethrow(java.lang.Throwable throwable)
The use of this technique may be controversial, but exceedingly useful to library developers.
  public int propagateExample { // note that there is no throws clause
      try {
          return invocation(); // throws IOException
      } catch (Exception e) {
          return ExceptionUtils.rethrow(e);  // propagates a checked exception
      }
  }
 
 This is an alternative to the more conservative approach of wrapping the checked exception in a RuntimeException:
  public int wrapExample { // note that there is no throws clause
      try {
          return invocation(); // throws IOException
      } catch (Error e) {
          throw e;
      } catch (RuntimeException e) {
          throw e;  // wraps a checked exception
      } catch (Exception e) {
          throw new UndeclaredThrowableException(e);  // wraps a checked exception
      }
  }
 
 One downside to using this approach is that the java compiler will not allow invoking code to specify a checked exception in a catch clause unless there is some code path within the try block that has invoked a method declared with that checked exception. If the invoking site wishes to catch the shaded checked exception, it must either invoke the shaded code through a method re-declaring the desired checked exception, or catch Exception and use the instanceof operator. Either of these techniques are required when interacting with non-java jvm code such as Jython, Scala, or Groovy, since these languages do not consider any exceptions as checked.
R - The type of the returned value.throwable - The throwable to rethrow.wrapAndThrow(Throwable)public static java.util.stream.Stream<java.lang.Throwable> stream(java.lang.Throwable throwable)
 A throwable without cause will return a stream containing one element - the input throwable. A throwable with one cause
 will return a stream containing two elements. - the input throwable and the cause throwable. A null throwable
 will return a stream of count zero.
 
This method handles recursive cause structures that might otherwise cause infinite loops. The cause chain is processed until the end is reached, or until the next item in the chain is already in the result set.
throwable - The Throwable to traversepublic static <T extends java.lang.Throwable> T throwableOfThrowable(java.lang.Throwable throwable,
                                                                     java.lang.Class<T> clazz)
Throwable
 that matches the specified class (exactly) in the exception chain.
 Subclasses of the specified class do not match - see
 throwableOfType(Throwable, Class) for the opposite.
 A null throwable returns null.
 A null type returns null.
 No match in the chain returns null.
T - the type of Throwable you are searching.throwable - the throwable to inspect, may be nullclazz - the class to search for, subclasses do not match, null returns nullpublic static <T extends java.lang.Throwable> T throwableOfThrowable(java.lang.Throwable throwable,
                                                                     java.lang.Class<T> clazz,
                                                                     int fromIndex)
Throwable
 that matches the specified type in the exception chain from
 a specified index.
 Subclasses of the specified class do not match - see
 throwableOfType(Throwable, Class, int) for the opposite.
 A null throwable returns null.
 A null type returns null.
 No match in the chain returns null.
 A negative start index is treated as zero.
 A start index greater than the number of throwables returns null.
T - the type of Throwable you are searching.throwable - the throwable to inspect, may be nullclazz - the class to search for, subclasses do not match, null returns nullfromIndex - the (zero-based) index of the starting position,
  negative treated as zero, larger than chain size returns nullpublic static <T extends java.lang.Throwable> T throwableOfType(java.lang.Throwable throwable,
                                                                java.lang.Class<T> type)
Throwable
 that matches the specified class or subclass in the exception chain.
 Subclasses of the specified class do match - see
 throwableOfThrowable(Throwable, Class) for the opposite.
 A null throwable returns null.
 A null type returns null.
 No match in the chain returns null.
T - the type of Throwable you are searching.throwable - the throwable to inspect, may be nulltype - the type to search for, subclasses match, null returns nullpublic static <T extends java.lang.Throwable> T throwableOfType(java.lang.Throwable throwable,
                                                                java.lang.Class<T> type,
                                                                int fromIndex)
Throwable
 that matches the specified type in the exception chain from
 a specified index.
 Subclasses of the specified class do match - see
 throwableOfThrowable(Throwable, Class) for the opposite.
 A null throwable returns null.
 A null type returns null.
 No match in the chain returns null.
 A negative start index is treated as zero.
 A start index greater than the number of throwables returns null.
T - the type of Throwable you are searching.throwable - the throwable to inspect, may be nulltype - the type to search for, subclasses match, null returns nullfromIndex - the (zero-based) index of the starting position,
  negative treated as zero, larger than chain size returns nullpublic static <T> T throwUnchecked(T throwable)
Throwable
 should be thrown and does it if necessary.T - The Throwable type.throwable - the throwable to test and throw or return.public static <R> R wrapAndThrow(java.lang.Throwable throwable)
The downside to using this approach is that invoking code which needs to handle specific checked exceptions must sniff up the exception chain to determine if the caught exception was caused by the checked exception.
R - The type of the returned value.throwable - The throwable to rethrow.rethrow(Throwable), 
hasCause(Throwable, Class)Copyright © 2010 - 2023 Adobe. All Rights Reserved