一:抽象类Assert

抽象类不能够实例化对象,但是可以被继承,Assert类是功能类,所以方法都是static修饰

所以可以直接  类名.方法 调用。

public abstract class Assert

构造方法:

抽象类中的构造方法的意义,其实不是很大,因为它不能实例化对象,所以不会调用,但是

如果有类继承Assert类,那么就会在子类中调用父类的构造方法,如果父类中构造方法时自定义

的有参构造,那么在子类构造方法中就要显示的调用,如果是无参构造,那么不用再子类中显示的

调用,默认就会调用父类的无参构造方法。

 public Assert()
{
}

重载了两个isTrue方法,判断表达式是否是true,这种重载的方式构造代码很好,使用

比较灵活

public static void isTrue(boolean expression, String message)
{
     //如果表达式的值为false,那么会抛出非法参数异常,如果是true,则结束方法的调用,return
if(!expression)
throw new IllegalArgumentException(message);
else
return;
}
  //客户端程序员在使用的使用,可以直接调这个方法,如果想自定义异常信息,可以调用上面那个
public static void isTrue(boolean expression)
{
isTrue(expression, "[Assertion failed] - this expression must be true");
}

重载两个isNull的方法,判断对象object是否为null

public static void isNull(Object object, String message)
{  
     //如果object不为null,则抛参数异常,为null则结束调用
if(object != null)
throw new IllegalArgumentException(message);
else
return;
}
  判断object为null,如果想要自定义异常message,则可以调用上面那个方法
public static void isNull(Object object)
{
isNull(object, "[Assertion failed] - the object argument must be null");
}

 

重载两个notNull方法,判断object是否非null

 public static void notNull(Object object, String message)
{
     //如果object为null,则抛非法参数异常,否则结束方法调用,return
if(object == null)
throw new IllegalArgumentException(message);
else
return;
}
  //如果需要自己定义抛出异常message,需要调用上面的方法
public static void notNull(Object object)
{
notNull(object, "[Assertion failed] - this argument is required; it must not be null");
}

判断字符串text是否有长度,就是是否为空(包括null或者"")

public static void hasLength(String text, String message)
{
     //如果为空,则抛非法参数异常,否则直接结束方法的调用,return
if(!StringUtils.hasLength(text))
throw new IllegalArgumentException(message);
else
return;
}
  //一般可以使用该方法直接判断text是否为空,如果需要自定义异常message信息,可以调用上面的方法
public static void hasLength(String text)
{
hasLength(text, "[Assertion failed] - this String argument must have length; it must not be null or empty");
}
StringUtils.hasLength(text)
这里引入了相同包向的StringUtils类的hasLength方法
public static boolean hasLength(CharSequence str)
{
     //判断是否有长度,就是判断是否为null或者""
return str != null && str.length() > 0;
}
  //入参为String,调用重载方法,入参为字符序列,字符序列是接口,String类以及StringBuilder以及StringBuffer的父类
public static boolean hasLength(String str)
{
return hasLength(((CharSequence) (str)));
}

  

重载两个方法hasText,判断字符串是否有内容,就是判断字符串text不会null或者"",或者空白,例如:"   "

 public static void hasText(String text, String message)
{
     //为空(包括空白" "),则抛参数非法异常,否则结束方法调用
if(!StringUtils.hasText(text))
throw new IllegalArgumentException(message);
else
return;
}
  /如果为了自定义异常描述,可以调用上面的方法
public static void hasText(String text)
{
hasText(text, "[Assertion failed] - this String argument must have text; it must not be null, empty, or blank");
}
StringUtils.hasText(text)这里引入了StringUtils类下的hasText方法
 public static boolean hasText(CharSequence str)
{
     //如果为null或者"",则直接返回false,没有内容
if(!hasLength(str))
return false;
int strLen = str.length();
     //遍历字符串,得到每一个字符,如果有一个字符不是空白,就证明有内容,返回true,否则(所以都是空白),则返回false
for(int i = 0; i < strLen; i++)
          
if(!Character.isWhitespace(str.charAt(i)))
return true; return false;
}
  //重载入参为字符串String的方法
public static boolean hasText(String str)
{
return hasText(((CharSequence) (str)));
}

  

判断字符串textToSearch中不包含substring子串

 public static void doesNotContain(String textToSearch, String substring, String message)
{
     //如果字符串textToSearch以及subString都不为空,并且textToSearch包含子串substring,则抛出异常,否则return结束方法调用
if(StringUtils.hasLength(textToSearch) && StringUtils.hasLength(substring) && textToSearch.contains(substring))
throw new IllegalArgumentException(message);
else
return;
}
  //如果需要自定义异常信息message,则可以直接调用上面的方法
public static void doesNotContain(String textToSearch, String substring)
{
doesNotContain(textToSearch, substring, (new StringBuilder()).append("[Assertion failed] - this String argument must not contain the substring [").append(substring).append("]").toString());
}

这里有

textToSearch.contains(substring) 方法:来自于String类的方法contains()
  public boolean contains(CharSequence s) {
return indexOf(s.toString()) > -1;
}

包含调用indexOf则返回索引,不包含则返回-1

判断数组array是否非空

 public static void notEmpty(Object array[], String message)
{  
     //如果数组array为空,则抛参数非法异常,否则结束方法的调用
if(ObjectUtils.isEmpty(array))
throw new IllegalArgumentException(message);
else
return;
}
  //自定义异常信息,则调用上面重载的方法更加灵活
public static void notEmpty(Object array[])
{
notEmpty(array, "[Assertion failed] - this array must not be empty: it must contain at least 1 element");
}

这里调用

ObjectUtils.isEmpty(array)方法:
public static boolean isEmpty(Object array[])
{
     //如果数组array为null或者长度length为0则为空
return array == null || array.length == 0;
}

 

判断数组array没有null元素

 public static void noNullElements(Object array[], String message)
{
     //如果array非null,则取出array数组中的每一个元素和null进行比较,如果有一个为null则抛出异常
if(array != null)
{
Object arr$[] = array; //这里面有个地址复制的动作,将array数组对象的地址给了arr,这样在栈中就有两个地址指向array数组对象
int len$ = arr$.length;
for(int i$ = 0; i$ < len$; i$++)
{
Object element = arr$[i$];
if(element == null)
throw new IllegalArgumentException(message);
} }
} public static void noNullElements(Object array[])
{
noNullElements(array, "[Assertion failed] - this array must not contain any null elements");
}

对于集合Collection的非空判断

public static void notEmpty(Collection collection, String message)
{
//如果collection集合为空,则抛出参数非法异常,否则结束方法调用,直接return
if(CollectionUtils.isEmpty(collection))
throw new IllegalArgumentException(message);
else
return;
} public static void notEmpty(Collection collection)
{
notEmpty(collection, "[Assertion failed] - this collection must not be empty: it must contain at least 1 element");
}
CollectionUtils.isEmpty(collection)
 public static boolean isEmpty(Collection collection)
{
     //集合为null或没有元素
return collection == null || collection.isEmpty();
}

 

判断集合map非空,如果为空,则抛异常

public static void notEmpty(Map map, String message)
{
if(CollectionUtils.isEmpty(map))
throw new IllegalArgumentException(message);
else
return;
} public static void notEmpty(Map map)
{
notEmpty(map, "[Assertion failed] - this map must not be empty; it must contain at least one entry");
}

  

CollectionUtils.isEmpty(map)
 public static boolean isEmpty(Map map)
{
return map == null || map.isEmpty();
}

  

判断obj对象是否是clazz类的实例

 public static void isInstanceOf(Class clazz, Object obj)
{
isInstanceOf(clazz, obj, "");
}
  
public static void isInstanceOf(Class type, Object obj, String message)
{
     //如果obj不是type的实例,则抛出异常
notNull(type, "Type to check against must not be null");
if(!type.isInstance(obj))
throw new IllegalArgumentException((new StringBuilder()).append(StringUtils.hasLength(message) ? (new StringBuilder()).append(message).append(" ").toString() : "").append("Object of class [").append(obj == null ? "null" : obj.getClass().getName()).append("] must be an instance of ").append(type).toString());
else
return;
}

isInstanceOf方法用法类似与运算符instanceof

判断superType等于subType或者是subType的父类

 public static void isAssignable(Class superType, Class subType)
{
isAssignable(superType, subType, "");
} public static void isAssignable(Class superType, Class subType, String message)
{
notNull(superType, "Type to check against must not be null");
     //如果subType为null或者superType不是subType的父类或者相同,那么抛出异常
if(subType == null || !superType.isAssignableFrom(subType))
throw new IllegalArgumentException((new StringBuilder()).append(message).append(subType).append(" is not assignable to ").append(superType).toString());
else
return;
}

  

重载两个方法state,用途类似与之前的isTrue方法

public static void state(boolean expression, String message)
{
if(!expression)
throw new IllegalStateException(message);
else
return;
} public static void state(boolean expression)
{
state(expression, "[Assertion failed] - this state invariant must be true");
}

  

二:总结

spring框架是优秀的第三方框架,代码的设计架构比较良好,仔细研究学习,对自己的编程会有很多的帮助,spring的代码中

很多创建重载的方法,这样使用起来更加灵活,可以更加业务场景,自定义异常信息,今天就写到这里,后续再继续整理。

源码分析六(org.springframework.util包之Assert类)的更多相关文章

  1. 源码分析八(org.springframework.util包之StringUtils类))

    一:spring框架util包中的StringUtils类主要是处理关于字符串 的功能方法,下面直接结合代码分析: //判断字符串是否为空,如果为nul或者""则返回true,否则 ...

  2. 一点一点看JDK源码(六)java.util.LinkedList前篇之链表概要

    一点一点看JDK源码(六)java.util.LinkedList前篇之链表概要 liuyuhang原创,未经允许禁止转载 本文举例使用的是JDK8的API 目录:一点一点看JDK源码(〇) 1.什么 ...

  3. motan源码分析六:客户端与服务器的通信层分析

    本章将分析motan的序列化和底层通信相关部分的代码. 1.在上一章中,有一个getrefers的操作,来获取所有服务器的引用,每个服务器的引用都是由DefaultRpcReferer来创建的 pub ...

  4. ABP源码分析六:依赖注入的实现

    ABP的依赖注入的实现有一个本质两个途径:1.本质上是依赖于Castle这个老牌依赖注入的框架.2.一种实现途径是通过实现IConventionalDependencyRegistrar的实例定义注入 ...

  5. Duilib源码分析(六)整体流程

    在<Duilib源码分析(一)整体框架>.<Duilib源码分析(二)控件构造器—CDialogBuilder>以及<Duilib源码分析(三)XML解析器—CMarku ...

  6. Vue.js 源码分析(六) 基础篇 计算属性 computed 属性详解

    模板内的表达式非常便利,但是设计它们的初衷是用于简单运算的.在模板中放入太多的逻辑会让模板过重且难以维护,比如: <div id="example">{{ messag ...

  7. vuex 源码分析(六) 辅助函数 详解

    对于state.getter.mutation.action来说,如果每次使用的时候都用this.$store.state.this.$store.getter等引用,会比较麻烦,代码也重复和冗余,我 ...

  8. dubbo源码分析2——SPI机制中的SPI实现类的读取和预处理

    SPI机制中的SPI实现类的读取和预处理是由ExtensionLoader类的loadFile方法来完成的 loadFile方法的作用是读取dubbo的某个SPI接口的spi描述文件,然后进行缓存,缓 ...

  9. Spring源码分析-从@ComponentScan注解配置包扫描路径到IoC容器中的BeanDefinition,经历了什么(一)?

    阅前提醒 全文较长,建议沉下心来慢慢阅读,最好是打开Idea,点开Spring源码,跟着下文一步一步阅读,更加便于理解.由于笔者水平优先,编写时间仓促,文中难免会出现一些错误或者不准确的地方,恳请各位 ...

随机推荐

  1. 【WPF】右键菜单ContextMenu可点击区域太小的问题

    问题描述 正常使用右键菜单ContextMenu时,如果菜单项是不变的,可以直接在XAML中写死,如下是给一个Button按钮添加了右键菜单功能. <Button Content="T ...

  2. DLL接口的实现(虚函数)

    DLL接口的实现(虚函数) 我们在c++编程过程中往往要用到各种不同形式的程序库,这些库的发布方式有动态库和静态库.对于静态类库,设计良好的静态类库能实现功能上的隔离,无法避免类库实现必须重新编译.链 ...

  3. gdb 内存查看

    (gdb) x /4xw 0xc20000000xc2000000:    0x00001111    0x22223333    0x00001111    0x22223333(gdb) x /8 ...

  4. Java编程的逻辑 (73) - 并发容器 - 写时拷贝的List和Set

    ​本系列文章经补充和完善,已修订整理成书<Java编程的逻辑>,由机械工业出版社华章分社出版,于2018年1月上市热销,读者好评如潮!各大网店和书店有售,欢迎购买,京东自营链接:http: ...

  5. sql server 2012 删除服务器名称

    SQL Server 2008 R2及以前版本: http://blog.csdn.net/downmoon/article/details/5678468 SQL Server 2012: 删除这两 ...

  6. iOS应用跳转到App Store评分

    iOS应用跳转到App Store评分 1.跳转到应用评价页 NSString *urlStr = [NSString stringWithFormat:@"itms-apps://itun ...

  7. python使用pymongo访问MongoDB的基本操作,以及CSV文件导出

    1. 环境. Python:3.6.1 Python IDE:pycharm 系统:win7 2. 简单示例 import pymongo # mongodb服务的地址和端口号mongo_url = ...

  8. node学习笔记2——搭建服务器

    搭建服务器关键词: require('http') —— 请求 node 里面的 http 模块 createServer —— 创建一个服务器 request —— 请求 response—— 响应 ...

  9. 解决华为手机图片选择无效及产生的open failed: EACCES (Permission denied)错误

    在华为手机上调起图片选择时原来的效果如下 原来的代码是 Intent intent = new Intent(); intent.setAction(Intent.ACTION_GET_CONTENT ...

  10. OpenGL 阴影之Shadow Mapping和Shadow Volumes

    先说下开发环境.VS2013,C++空项目,引用glut,glew.glut包含基本窗口操作,免去我们自己新建win32窗口一些操作.glew使我们能使用最新opengl的API,因winodw本身只 ...