方法简介:
此类包含static实用程序方法,用于操作对象或在操作前检查某些条件。 这些实用程序包括null或null方法,用于计算对象的哈希代码,返回对象的字符串,比较两个对象,以及检查索引或子范围值是否超出范围。
该类为静态工具类,不可实例化。构造函数是私有的。
//1、检查下标是否越界,检查是否在子范围从 fromIndex (包括)到 fromIndex + size (不包括)是范围界限内 0 (包括)到 length (不包括)。
checkFromToIndex(int fromIndex, int toIndex, int length)
checkFromIndexSize(int fromIndex, int size, int length)
//2、检查下标是否越界
checkIndex(int index, int length)
//3、如果参数相同则返回0,否则返回 c.compare(a, b) 。
compare(T a, T b, Comparator<? super T> c)
//4、区别
deepEquals(Object a, Object b)\equals(Object a, Object b)\eauals(object)
equals:
public boolean equals(Object obj) {
return (this == obj);
}
equals(Object a, Object b):
public static boolean equals(Object a, Object b) {
return (a == b) || (a != null && a.equals(b));
}
deepEquals(Object a, Object b)
public static boolean deepEquals(Object a, Object b) {
if (a == b)
return true;
else if (a == null || b == null)
return false;
else
return Arrays.deepEquals0(a, b);
}
//5、判断是否为空。
isNull(Object obj)/nonNull(Object obj)
//6、检查指定的对象引用是否不是 null 。 抛异常的方式提醒
requireNonNull(T obj)/requireNonNull(T obj, String message)
/*7、检查指定的对象引用是否为null ,如果是,则抛出自定义的NullPointerException 。
与方法requireNonNull(Object, String)不同,此方法允许创建要延迟的消息,直到进行空检查。
虽然这可以在非空情况下赋予性能优势,但在决定调用此方法时,应注意创建消息提供者的成本小于仅直接创建字符串消息的成本。*/
requireNonNull(T obj, Supplier<String> messageSupplier)
//8、如果它是非 null ,则返回第一个参数,否则返回非 null第二个参数。
requireNonNullElse(T obj, T defaultObj)
//9、如果它是非 null ,则返回第一个参数,否则返回非 null值 supplier.get()
requireNonNullElseGet(T obj, Supplier<? extends T> supplier)
//10、2与1的区别在于如果第一个参数不是 null ,则返回在第一个参数上调用 toString的结果,否则返回第二个参数;1则是若为空,则返回“null”
toString(Object o)
toString(Object o, String nullDefault)