本文共 1276 字,大约阅读时间需要 4 分钟。
译者: 沈义扬
前置条件:让方法调用的前置条件判断更简单。
Guava在类中提供了若干前置条件判断的实用方法,我们强烈建议。每个方法都有三个变种:
1 | checkArgument(i >= 0 , "Argument was %s but expected nonnegative" , i); |
2 | checkArgument(i < j, "Expected i < j, but %s > %s" , i, j); |
方法声明(不包括额外参数) | 描述 | 检查失败时抛出的异常 |
检查boolean是否为true,用来检查传递给方法的参数。 | IllegalArgumentException | |
检查value是否为null,该方法直接返回value,因此可以内嵌使用checkNotNull。 | NullPointerException | |
用来检查对象的某些状态。 | IllegalStateException | |
检查index作为索引值对某个列表、字符串或数组是否有效。index>=0 && index<size * | IndexOutOfBoundsException | |
检查index作为位置值对某个列表、字符串或数组是否有效。index>=0 && index<=size * | IndexOutOfBoundsException | |
检查[start, end]表示的位置范围对某个列表、字符串或数组是否有效* | IndexOutOfBoundsException |
译者注:
*索引值常用来查找列表、字符串或数组中的元素,如List.get(int), String.charAt(int)
*位置值和位置范围常用来截取列表、字符串或数组,如List.subList(int,int), String.substring(int)
相比Apache Commons提供的类似方法,我们把Guava中的Preconditions作为首选。Piotr Jagielski在中简要地列举了一些理由:
在编码时,如果某个值有多重的前置条件,我们建议你把它们放到不同的行,这样有助于在调试时定位。此外,把每个前置条件放到不同的行,也可以帮助你编写清晰和有用的错误消息。
转载地址:http://xtoel.baihongyu.com/