Guava Preconditions的自定义异常

时间:2013-12-20 15:36:38

标签: java guava preconditions

这是一个非常简单的问题,我经常在项目中使用com.google.common.base.Preconditions来验证参数和参数,例如:

Preconditions.checkNotNull(parameter, "message");
Preconditions.checkArgument(parameter > 0, "message");

此代码可能会产生IllegalArgumentException或NPE。但是我经常需要抛出自己的异常。 我怎么能通过这个图书馆做到这一点?或者也许你可以建议另一个? 提前谢谢你!

更新:我明白,我可以创建自己的简单实用工具类,但我有兴趣找到现成的解决方案。如果有人知道这是可能的,请告诉我。

5 个答案:

答案 0 :(得分:6)

如果你想抛出自己的异常,只需使用与Preconditions中类似的方法创建自己的类。这些方法中的每一种都非常简单 - 与编写自己的方法相比,添加某种“插件”功能以允许指定异常类实际上是过度的。

您始终可以使用source of Preconditions作为起点。

答案 1 :(得分:3)

这是我最终找到的解决方案。它完全符合我的要求。可能对任何人都有用:

import java.lang.reflect.InvocationTargetException;

// IMPORTANT: parameter exClass must have at least no args constructor and constructor with String param
public class Precondition {

public static <T extends Exception> void checkArgument(boolean expression, Class<T> exClass) throws T {
    checkArgument(expression, exClass, null);
}

public static <T extends Exception> void checkArgument(boolean expression, Class<T> exClass, String errorMessage, Object... args) throws T {
    if (!expression) {
        generateException(exClass, errorMessage, args);
    }
}

public static <T extends Exception> void checkNotNull(Object reference, Class<T> exClass) throws T {
    checkNotNull(reference, exClass, null);
}

public static <T extends Exception> void checkNotNull(Object reference, Class<T> exClass, String errorMessage, Object... args) throws T {
    if (reference == null) {
        generateException(exClass, errorMessage, args);
    }
}

private static <T extends Exception> void generateException(Class<T> exClass, String errorMessage, Object... args) throws T {
    try {
        if (errorMessage == null) {
            throw exClass.newInstance();
        } else {
            throw exClass.getDeclaredConstructor(String.class, Object[].class).newInstance(errorMessage, args);
        }
    } catch (InstantiationException | NoSuchMethodException | InvocationTargetException | IllegalAccessException e) {
        e.printStackTrace();
    }
}

}

答案 2 :(得分:2)

您可以将valid4j与hamcrest-matchers一起使用(在Maven Central上找到org.valid4j:valid4j)

用于投掷自定义异常的输入验证:

import static org.valid4j.Validation.*;

validate(argument, isValid(), otherwiseThrowing(InvalidException.class));

对于前置条件和后置条件(即断言):

import static org.valid4j.Assertive.*;

require(argument, notNullValue());
...
ensure(result, isValid());

链接:

答案 3 :(得分:2)

你总是可以为自己创造类似的东西(我不知道为什么来自番石榴的家伙还没有添加它):

public static void check(final boolean expression, RuntimeException exceptionToThrow) {
    if (!expression) {
        throw checkNotNull(exceptionToThrow);
    }
}

public static void check(final boolean expression, Supplier<? extends RuntimeException> exceptionToThrowSupplier) {
    if (!expression) {
        throw checkNotNull(exceptionToThrowSupplier).get();
    }
}

答案 4 :(得分:1)

Exception类型被硬编码到Preconditions类中。您需要实现自己的异常和自己的检查功能。您总是可以在自己的静态类中执行此操作,类似于Preconditions的工作方式。