- Guava 教程
- Guava - 首页
- Guava - 概述
- Guava - 环境搭建
- Guava - Optional 类
- Guava - Preconditions 类
- Guava - Ordering 类
- Guava - Objects 类
- Guava - Range 类
- Guava - Throwables 类
- Guava - 集合工具类
- Guava - 缓存工具类
- Guava - 字符串工具类
- Guava - 基本类型工具类
- Guava - 数学工具类
- Guava 有用资源
- Guava - 快速指南
- Guava - 有用资源
- Guava - 讨论
Guava - Optional 类
Optional 是一个不可变对象,用于包含一个非空对象。Optional 对象用于表示空值,即不存在的值。此类包含各种实用方法,以方便代码处理可用或不可用的值,而不是检查空值。
类声明
以下是 com.google.common.base.Optional<T> 类的声明:
@GwtCompatible(serializable = true)
public abstract class Optional<T>
extends Object
implements Serializable
类方法
| 序号 | 方法及描述 |
|---|---|
| 1 | static <T> Optional<T> absent() 返回一个不包含引用的 Optional 实例。 |
| 2 | abstract Set<T> asSet() 如果存在包含的实例,则返回一个其唯一元素为包含实例的不可变单例 Set;否则返回一个空的不可变 Set。 |
| 3 | abstract boolean equals(Object object) 如果 object 是一个 Optional 实例,并且包含的引用彼此相等或两者都不存在,则返回 true。 |
| 4 | static <T> Optional<T> fromNullable(T nullableReference) 如果 nullableReference 不为空,则返回包含该引用的 Optional 实例;否则返回 absent()。 |
| 5 | abstract T get() 返回包含的实例,该实例必须存在。 |
| 6 | abstract int hashCode() 返回此实例的哈希码。 |
| 7 | abstract boolean isPresent() 如果此持有者包含一个(非空)实例,则返回 true。 |
| 8 | static <T> Optional<T> of(T reference) 返回包含给定非空引用的 Optional 实例。 |
| 9 | abstract Optional<T> or(Optional<? extends T> secondChoice) 如果此 Optional 有值存在,则返回此 Optional;否则返回 secondChoice。 |
| 10 | abstract T or(Supplier<? extends T> supplier) 如果包含的实例存在,则返回该实例;否则返回 supplier.get()。 |
| 11 | abstract T or(T defaultValue) 如果包含的实例存在,则返回该实例;否则返回 defaultValue。 |
| 12 | abstract T orNull() 如果包含的实例存在,则返回该实例;否则返回 null。 |
| 13 | static <T> Iterable<T> presentInstances(Iterable<? extends Optional<? extends T>> optionals) 按顺序返回提供的 optionals 中每个存在实例的值,跳过 absent() 的出现。 |
| 14 | abstract String toString() 返回此实例的字符串表示形式。 |
| 15 | abstract <V> Optional<V> transform(Function<? super T,V> function) 如果实例存在,则使用给定的 Function 对其进行转换;否则,返回 absent()。 |
继承的方法
此类继承自以下类:
- java.lang.Object
Optional 类的示例
使用您选择的任何编辑器创建以下 Java 程序,例如在 C:/> Guava. 中。
GuavaTester.java
import com.google.common.base.Optional;
public class GuavaTester {
public static void main(String args[]) {
GuavaTester guavaTester = new GuavaTester();
Integer value1 = null;
Integer value2 = new Integer(10);
//Optional.fromNullable - allows passed parameter to be null.
Optional<Integer> a = Optional.fromNullable(value1);
//Optional.of - throws NullPointerException if passed parameter is null
Optional<Integer> b = Optional.of(value2);
System.out.println(guavaTester.sum(a,b));
}
public Integer sum(Optional<Integer> a, Optional<Integer> b) {
//Optional.isPresent - checks the value is present or not
System.out.println("First parameter is present: " + a.isPresent());
System.out.println("Second parameter is present: " + b.isPresent());
//Optional.or - returns the value if present otherwise returns
//the default value passed.
Integer value1 = a.or(new Integer(0));
//Optional.get - gets the value, value should be present
Integer value2 = b.get();
return value1 + value2;
}
}
验证结果
使用 javac 编译器编译该类,如下所示:
C:\Guava>javac GuavaTester.java
现在运行 GuavaTester 以查看结果。
C:\Guava>java GuavaTester
查看结果。
First parameter is present: false Second parameter is present: true 10