处理“受限制”代码中的异常

时间:2012-02-06 07:23:02

标签: java exception exception-handling

我最近提出了另一个问题,避免在不需要时使用样板例外(或者更具体地说,不需要处理错误,因为如果首先调用错误,应用程序就无法生存)。在大多数情况下,我决定转向支持未经检查的错误,主要是为了便于阅读。在其他情况下,我似乎别无选择,只能使用大而丑陋的try catch块。

例如,在一种情况下,我使用apache commons BeanUtilities类MethodUtils,以便使用内省来调用未知类型的Object中的方法。在这种情况下,看看我如何使用我无法控制的类。我是否被迫遵循已检查的异常原则并在每次使用该方法时捕获3个不同的异常?或者有办法解决这个问题吗?

SQL sql = null;
try {
    sql = (SQL) MethodUtils.invokeExactMethod(bean, "getSQL", (Object[])null);
} catch (NoSuchMethodException e) {
    e.printStackTrace();
} catch (IllegalAccessException e) {
    e.printStackTrace();
} catch (InvocationTargetException e) {
    e.printStackTrace();
}

2 个答案:

答案 0 :(得分:2)

复杂catch可读性是一个非常常见的问题。在Java 7中,它可以是更易读的形式:

SQL sql = null;
try {
    sql = (SQL) MethodUtils.invokeExactMethod(bean, "getSQL", (Object[])null);
} catch (NoSuchMethodException | IllegalAccessException | InvocationTargetException e) {
    e.printStackTrace();
}

答案 1 :(得分:0)

除了Mersenne的答案,您可以在catch块中简单地使用这些异常的公共基类:

SQL sql = null;
try {
    sql = (SQL) MethodUtils.invokeExactMethod(bean, "getSQL", (Object[])null);
} catch (Exception e) {
    e.printStackTrace();
}

这将捕获所有三个例外。如果您不打算对不同的例外执行任何特定措施,这是一个合适的解决方案。它适用于所有JDK版本。