java编程中的断言工具类(org.springframework.util.Assert)

来源:互联网 发布:js 判断有没有滚动条 编辑:程序博客网 时间:2024/05/21 17:18

断言工具类:Assert类,

java.lang.Object --->org.springframework.util.Assert
 

先举个例子,

当我们在编写类的方法时,常常需要对方法入参进行合法性检查,如果入参不符合要求,方法将通过抛出异常的方式拒绝后续处理。如下所示:

public InputStream getData(String file) {

         if (file == null || file.length() == 0|| file.replaceAll("\\s", "").length() == 0) {

                  throw new IllegalArgumentException("file入参不是有效的文件地址");

         }

          …

}

类似以上检测方法入参的代码是非常常见,但是在每个方法中都使用手工编写检测逻辑的方式并不是一个好主意。阅读 Spring 源码,您会发现Spring 采用一个 org.springframework.util.Assert 通用类完成这一任务。

Assert 翻译为中文为“断言”,使用过 JUnit 的读者都熟知这个概念,它断定某一个实际的运行值和预期想一样,否则就抛出异常。Spring 对方法入参的检测借用了这个概念,其提供的 Assert 类拥有众多按规则对方法入参进行断言的方法,可以满足大部分方法入参检测的要求。这些断言方法在入参不满足要求时就会抛出 IllegalArgumentException。下面,我们来认识一下 Assert 类中的常用断言方法:

断言方法说明notNull(Object object)当 object 为 null 时抛出异常,notNull(Object object, String message) 方法允许您通过 message 定制异常信息。和 notNull() 方法断言规则相反的方法是 isNull(Object object)/isNull(Object object, String message),它要求入参一定是 null;isTrue(boolean expression) / isTrue(boolean expression, String message)当 expression 不为 true 抛出异常;notEmpty(Collection collection) / notEmpty(Collection collection, String message)当集合未包含元素时抛出异常。notEmpty(Map map) / notEmpty(Map map, String message) 和 notEmpty(Object[] array, String message) / notEmpty(Object[] array, String message) 分别对 Map 和 Object[] 类型的入参进行判断;hasLength(String text) / hasLength(String text, String message)当 text 为 null 或长度为 0 时抛出异常;hasText(String text) / hasText(String text, String message)text 不能为 null 且必须至少包含一个非空格的字符,否则抛出异常;isInstanceOf(Class clazz, Object obj) / isInstanceOf(Class type, Object obj, String message)如果 obj 不能被正确造型为 clazz 指定的类将抛出异常;isAssignable(Class superType, Class subType) / isAssignable(Class superType, Class subType, String message)subType 必须可以按类型匹配于 superType,否则将抛出异常;

 

使用 Assert 断言类可以简化方法入参检测的代码,如 InputStream getData(String file) 在应用 Assert 断言类后,其代码可以简化为以下的形式:

public InputStream getData(String file){
         Assert.hasText(file,"file入参不是有效的文件地址");
         ① 使用 Spring 断言类进行方法入参检测
          …
 }

可见使用 Spring 的 Assert 替代自编码实现的入参检测逻辑后,方法的简洁性得到了不少的提高。Assert 不依赖于 Spring 容器,您可以大胆地在自己的应用中使用这个工具类。


方法摘要static voiddoesNotContain(java.lang.String textToSearch, java.lang.String substring)
          断言,给定的文本不包含给定的子串。static voiddoesNotContain(java.lang.String textToSearch, java.lang.String substring, java.lang.String message)
          断言,给定的文本不包含给定的子串。static voidhasLength(java.lang.String text)
          断言,由于String是不是空的,也就是说,它不能null ,而不是空字符串。static voidhasLength(java.lang.String text, java.lang.String message)
          断言,由于String是不是空的,也就是说,它不能null ,而不是空字符串。static voidhasText(java.lang.String text)
          断言定String具有有效的文本内容,即它不能null ,并且必须至少包含一个非空格字符。static voidhasText(java.lang.String text, java.lang.String message)
          断言定String具有有效的文本内容,即它不能null ,并且必须至少包含一个非空格字符。static voidisAssignable(java.lang.Class superType, java.lang.Class subType)
          断言superType.isAssignableFrom(subType)truestatic voidisAssignable(java.lang.Class superType, java.lang.Class subType, java.lang.String message)
          断言superType.isAssignableFrom(subType)truestatic voidisInstanceOf(java.lang.Class clazz, java.lang.Object obj)
          断言提供的对象是所提供的类的实例。static voidisInstanceOf(java.lang.Class type, java.lang.Object obj, java.lang.String message)
          断言提供的对象是所提供的类的实例。static voidisNull(java.lang.Object object)
          断言一个对象是nullstatic voidisNull(java.lang.Object object, java.lang.String message)
          断言一个对象是nullstatic voidisTrue(boolean expression)
          断言一个布尔表达式,扔IllegalArgumentException如果测试结果是falsestatic voidisTrue(boolean expression, java.lang.String message)
          断言一个布尔表达式,扔IllegalArgumentException如果测试结果是falsestatic voidnoNullElements(java.lang.Object[] array)
          断言一个数组没有null元素。static voidnoNullElements(java.lang.Object[] array, java.lang.String message)
          断言一个数组没有null元素。static voidnotEmpty(java.util.Collection collection)
          断言,一个集合有元素,也就是说,它不能null ,而且必须有至少一个元素。static voidnotEmpty(java.util.Collection collection, java.lang.String message)
          断言,一个集合有元素,也就是说,它不能null ,而且必须有至少一个元素。static voidnotEmpty(java.util.Map map)
          断言,一个地图的作品,也就是说,它不能null ,并且必须至少有一个条目。static voidnotEmpty(java.util.Map map, java.lang.String message)
          断言,一个地图的作品,也就是说,它不能null ,并且必须至少有一个条目。static voidnotEmpty(java.lang.Object[] array)
          断言一个数组元素,即它不能null ,而且必须有至少一个元素。static voidnotEmpty(java.lang.Object[] array, java.lang.String message)
          断言一个数组元素,即它不能null ,而且必须有至少一个元素。static voidnotNull(java.lang.Object object)
          断言一个对象不nullstatic voidnotNull(java.lang.Object object, java.lang.String message)
          断言一个对象不nullstatic voidstate(boolean expression)
          断言一个布尔表达式,扔IllegalStateException如果测试结果是falsestatic voidstate(boolean expression, java.lang.String message)
          断言一个布尔表达式,扔IllegalStateException如果测试结果是false 。 从类 java.lang.Object 继承的方法equals, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait

 

 

0 0
原创粉丝点击