java编程中的断言工具类(org.springframework.util.Assert)
转自:https://blog.csdn.net/gokeiryou263/article/details/19612471
断言工具类: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 void doesNotContain(java.lang.String textToSearch, java.lang.String substring)
断言,给定的文本不包含给定的子串。
static void doesNotContain(java.lang.String textToSearch, java.lang.String substring, java.lang.String message)
断言,给定的文本不包含给定的子串。
static void hasLength(java.lang.String text)
断言,由于String是不是空的,也就是说,它不能null ,而不是空字符串。
static void hasLength(java.lang.String text, java.lang.String message)
断言,由于String是不是空的,也就是说,它不能null ,而不是空字符串。
static void hasText(java.lang.String text)
断言定String具有有效的文本内容,即它不能null ,并且必须至少包含一个非空格字符。
static void hasText(java.lang.String text, java.lang.String message)
断言定String具有有效的文本内容,即它不能null ,并且必须至少包含一个非空格字符。
static void isAssignable(java.lang.Class superType, java.lang.Class subType)
断言superType.isAssignableFrom(subType)是true 。
static void isAssignable(java.lang.Class superType, java.lang.Class subType, java.lang.String message)
断言superType.isAssignableFrom(subType)是true 。
static void isInstanceOf(java.lang.Class clazz, java.lang.Object obj)
断言提供的对象是所提供的类的实例。
static void isInstanceOf(java.lang.Class type, java.lang.Object obj, java.lang.String message)
断言提供的对象是所提供的类的实例。
static void isNull(java.lang.Object object)
断言一个对象是null 。
static void isNull(java.lang.Object object, java.lang.String message)
断言一个对象是null 。
static void isTrue(boolean expression)
断言一个布尔表达式,扔IllegalArgumentException如果测试结果是false 。
static void isTrue(boolean expression, java.lang.String message)
断言一个布尔表达式,扔IllegalArgumentException如果测试结果是false 。
static void noNullElements(java.lang.Object[] array)
断言一个数组没有null元素。
static void noNullElements(java.lang.Object[] array, java.lang.String message)
断言一个数组没有null元素。
static void notEmpty(java.util.Collection collection)
断言,一个集合有元素,也就是说,它不能null ,而且必须有至少一个元素。
static void notEmpty(java.util.Collection collection, java.lang.String message)
断言,一个集合有元素,也就是说,它不能null ,而且必须有至少一个元素。
static void notEmpty(java.util.Map map)
断言,一个地图的作品,也就是说,它不能null ,并且必须至少有一个条目。
static void notEmpty(java.util.Map map, java.lang.String message)
断言,一个地图的作品,也就是说,它不能null ,并且必须至少有一个条目。
static void notEmpty(java.lang.Object[] array)
断言一个数组元素,即它不能null ,而且必须有至少一个元素。
static void notEmpty(java.lang.Object[] array, java.lang.String message)
断言一个数组元素,即它不能null ,而且必须有至少一个元素。
static void notNull(java.lang.Object object)
断言一个对象不null 。
static void notNull(java.lang.Object object, java.lang.String message)
断言一个对象不null 。
static void state(boolean expression)
断言一个布尔表达式,扔IllegalStateException如果测试结果是false 。
static void state(boolean expression, java.lang.String message)
断言一个布尔表达式,扔IllegalStateException如果测试结果是false 。
从类 java.lang.Object 继承的方法
equals, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
---------------------
作者:gokeiryou263
来源:CSDN
原文:https://blog.csdn.net/gokeiryou263/article/details/19612471
版权声明:本文为博主原创文章,转载请附上博文链接!
java编程中的断言工具类(org.springframework.util.Assert)的更多相关文章
- JAVA中封装JSONUtils工具类及使用
在JAVA中用json-lib-2.3-jdk15.jar包中提供了JSONObject和JSONArray基类,用于JSON的序列化和反序列化的操作.但是我们更习惯将其进一步封装,达到更好的重用. ...
- java 断言工具类
1.断言工具类 package com.sze.redis.util; import java.util.Collection; import java.util.Map; import com.sz ...
- Java 中的并发工具类
Java 中的并发工具类 CountDownLatch public class JoinCountDownLatchTest { public static void main(String[] a ...
- Java编程中“为了性能”尽量要做到的一些地方
最近的机器内存又爆满了,除了新增机器内存外,还应该好好review一下我们的代码,有很多代码编写过于随意化,这些不好的习惯或对程序语言的不了解是应该好好打压打压了. 下面是参考网络资源总结的一些在Ja ...
- java编程中'为了性能'一些尽量做到的地方
原文地址:http://blog.csdn.NET/m13666368773/article/details/7796924 最近的机器内存又爆满了,出了新增机器内存外,还应该好好review一下我们 ...
- 【Java基础】Java开发过程中的常用工具类库
目录 Java开发过程中的常用工具类库 1. Apache Commons类库 2. Guava类库 3. Spring中的常用工具类 4. 其他工具 参考 Java开发过程中的常用工具类库 1. A ...
- Java操作文件夹的工具类
Java操作文件夹的工具类 import java.io.File; public class DeleteDirectory { /** * 删除单个文件 * @param fileName 要删除 ...
- 深入剖析Java编程中的中文问题及建议最优解决方法
摘录自:http://fafeng.blogbus.com/logs/3062998.html http://www.blogbus.com/fafeng-logs/3063006.html 深入剖析 ...
- commons-lang3-3.2.jar中的常用工具类的使用
这个包中的很多工具类可以简化我们的操作,在这里简单的研究其中的几个工具类的使用. 1.StringUtils工具类 可以判断是否是空串,是否为null,默认值设置等操作: /** * StringUt ...
随机推荐
- Microsoft Azure 资料整理
鉴于Microsoft Azure的技术迭代更新相当快,所以推荐大家还是以官方文档为准. 以Global Azure 的为主,Mooncake版本自行删减 首先推荐Azure for MSDN htt ...
- 如何抓取崩溃的log日志
4.手机录屏工具的推荐 Andriod:录屏大师,易录屏等等. iOS:AirPlayer,iTools. 5.如何抓取崩溃的log日志? android闪退获取日志方法: 1.下载adb工具包 2. ...
- 【ZJOI2017 Round1练习】D8T1 mushroom(点分治)
题意: 思路: num[a[u]]表示存在a[u]这个颜色且终点在u子树中的链长总和 ans[i]表示以当前的u为根,前面的子树对i的贡献之和 ..]of longint; size,f,ans,su ...
- 【Tomcat】Tomcat Connector的三种运行模式【bio、nio、apr】
Tomcat Connector(Tomcat连接器)有bio.nio.apr三种运行模式 bio bio(blocking I/O,阻塞式I/O操作),表示Tomcat使用的是传统的Java I/O ...
- Linux下汇编语言学习笔记27 ---
这是17年暑假学习Linux汇编语言的笔记记录,参考书目为清华大学出版社 Jeff Duntemann著 梁晓辉译<汇编语言基于Linux环境>的书,喜欢看原版书的同学可以看<Ass ...
- fastcgi与cgi的区别[转载]
cgi 在2000年或更早的时候用得比较多, 以前web服务器一般只处理静态的请求,如果碰到一个动态请求怎么办呢?web服务器会根据这次请求的内容,然后会fork一个新进程来运行外部c程序 (或per ...
- IntentService用于服务中开启子线程的自动关闭
package com.pingyijinren.test; import android.app.IntentService; import android.content.Intent; impo ...
- SQL SERVER 2012 第三章 T-SQL 基本SELECT语句用法,Where子句详细用法
select [all|distinct] [top (<expression>) [Percent] [with ties]] <column list> [from < ...
- poj——3728 The merchant
The merchant Time Limit: 3000MS Memory Limit: 65536K Total Submissions: 5055 Accepted: 1740 Desc ...
- 04-js的运算符
<html> <head> <title>js的运算符学习</title> <meta charset="UTF-8"/> ...