|
The Spring Framework | |||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Object java.lang.Throwable java.lang.Exception org.springframework.core.NestedCheckedException
public abstract class NestedCheckedException
Handy class for wrapping checked Exceptions with a root cause.
This time-honored technique is no longer necessary in Java 1.4, which finally provides built-in support for exception nesting. Thus exceptions in applications written to use Java 1.4 need not extend this class. To ease migration, this class mirrors Java 1.4's nested exceptions as closely as possible.
Abstract to force the programmer to extend the class. getMessage
will include nested exception information; printStackTrace
etc will
delegate to the wrapped exception, if any.
The similarity between this class and the NestedRuntimeException class is unavoidable, as Java forces these two classes to have different superclasses (ah, the inflexibility of concrete inheritance!).
As discussed in Expert One-On-One J2EE Design and Development, runtime exceptions are often a better alternative to checked exceptions. However, all exceptions should preserve their stack trace, if caused by a lower-level exception.
getMessage()
,
printStackTrace(java.io.PrintStream)
,
NestedRuntimeException
,
Serialized FormConstructor Summary | |
---|---|
NestedCheckedException(String msg)
Construct a NestedCheckedException with the specified detail message. |
|
NestedCheckedException(String msg,
Throwable cause)
Construct a NestedCheckedException with the specified detail message
and nested exception. |
Method Summary | |
---|---|
boolean |
contains(Class exClass)
Check whether this exception contains an exception of the given class: either it is of the given class itself or it contains a nested cause of the given class. |
Throwable |
getCause()
Return the nested cause, or null if none. |
String |
getMessage()
Return the detail message, including the message from the nested exception if there is one. |
Throwable |
getRootCause()
Retrieve the innermost cause of this exception, if any. |
void |
printStackTrace(PrintStream ps)
Print the composite message and the embedded stack trace to the specified stream. |
void |
printStackTrace(PrintWriter pw)
Print the composite message and the embedded stack trace to the specified print writer. |
Methods inherited from class java.lang.Throwable |
---|
fillInStackTrace, getLocalizedMessage, getStackTrace, initCause, printStackTrace, setStackTrace, toString |
Methods inherited from class java.lang.Object |
---|
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait |
Constructor Detail |
---|
public NestedCheckedException(String msg)
NestedCheckedException
with the specified detail message.
msg
- the detail messagepublic NestedCheckedException(String msg, Throwable cause)
NestedCheckedException
with the specified detail message
and nested exception.
msg
- the detail messagecause
- the nested exceptionMethod Detail |
---|
public Throwable getCause()
null
if none.
Note that this will only check one level of nesting.
Use getRootCause()
to retrieve the innermost cause.
getCause
in class Throwable
getRootCause()
public String getMessage()
getMessage
in class Throwable
public void printStackTrace(PrintStream ps)
printStackTrace
in class Throwable
ps
- the print streampublic void printStackTrace(PrintWriter pw)
printStackTrace
in class Throwable
pw
- the print writerpublic Throwable getRootCause()
Currently just traverses NestedCheckedException causes. Will use the JDK 1.4 exception cause mechanism once Spring requires JDK 1.4.
null
if nonepublic boolean contains(Class exClass)
Currently just traverses NestedCheckedException causes. Will use the JDK 1.4 exception cause mechanism once Spring requires JDK 1.4.
exClass
- the exception class to look for
|
The Spring Framework | |||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |