我们几乎已经在我们的每个行业标准应用的代码中处理java自定义异常了。常见的手段是创建一个语义性的继承基础exception类的自定义异常类。
我们的新方法使用静态内部类来处理每个新的异常场景。
传统上我们通过继承 Exception
类来创建一个 DBException
。然后每次遇到需要抛出一个与数据库相关异常的时候,我们创建一个 DBException
的实例,添加一些信息之后抛出它。
现在让我们考虑以下我们需要抛出 DBException
的场景:
上述方法的问题在于当这些异常在catch块或者应用代码中被处理时, DBException
无法提供足够的信息来分别处理上面列出来的异常用例。
让我们为每一个用例创建一个内部类然后把它们组合到 DBException
内部来解决上述的问题吧。
首先创建一个抽象的 BaseException
来作为所有异常类的父类。
// BaseException.java public abstract class BaseException extends Exception{ private String message; public BaseException(String msg) { this.message = msg; } public String getMessage() { return message; } } 复制代码
现在创建我们的 Exception
内部类。
// DBExeption.java public class DBExeption { public static class BadExecution extends BaseException { private static final long serialVersionUID = 3555714415375055302L; public BadExecution(String msg) { super(msg); } } public static class NoData extends BaseException { private static final long serialVersionUID = 8777415230393628334L; public NoData(String msg) { super(msg); } } public static class MoreData extends BaseException { private static final long serialVersionUID = -3987707665150073980L; public MoreData(String msg) { super(msg); } } public static class InvalidParam extends BaseException { private static final long serialVersionUID = 4235225697094262603L; public InvalidParam(String msg) { super(msg); } } } 复制代码
这里我们创建了许多内部类来处理每一种异常情况。你可以根据实际情况随意扩展新的异常内部类。
为了理解它的作用,现在让我们来让我们创建一个异常然后抛出它。然后我们将会在日志中看见错误信息。
// TestExceptions.java public class TestExceptions { public static void main(String[] args) { try { throw new DBExeption.NoData("No row found for id : x"); } catch(Exception e) { e.printStackTrace(); } } } 复制代码
程序输出:
Console com.exception.DBExeption$NoData: No row found for id : x at com.test.TestExceptions.main(TestExceptions.java:7) 复制代码
正如你在异常栈中所见的日志消息,它所携带的信息更多更具体了。它清楚展示了错误是什么。在应用代码之中,你也可以通过检查自定义异常实例来做对应的处理。