可选的是用于包含非空对象的容器对象。可选对象用于表示缺少值的null。此类具有各种实用程序方法,以方便代码将值处理为“可用”或“不可用”,而不是检查空值。它是Java 8中引入的,类似于Guava中的Optional。
以下是java.util.Optional <T>类的声明-
public final class Optional<T> extends Object
序号 | 方法与说明 |
---|---|
1 | static <T> Optional <T>empty() 返回一个空的Optional实例。 |
2 | boolean equals(Object obj) 指示其他某个对象是否“等于”此Optional。 |
3 | Optional <T>过滤器(Predicate <?super <T>谓词) 如果存在一个值并且该值与给定谓词匹配,则返回描述该值的Optional,否则返回一个空的Optional。 |
4 | <U>可选<U> flatMap(Function <?super T,Optional <U >>映射器) 如果存在值,它将对其应用所提供的可选轴承映射函数,返回该结果,否则返回空的Optional。 |
5 | Tget() 如果此Optional中存在一个值,则返回该值,否则抛出NoSuchElementException。 |
6 | inthashCode() 返回当前值的哈希码值(如果有),如果没有值则返回0(零)。 |
7 | void ifPresent(Consumer <?super T> Consumer) 如果存在值,则使用该值调用指定的使用者,否则不执行任何操作。 |
8 | 布尔值isPresent() 如果存在值,则返回true,否则返回false。 |
9 | <U> Optional <U> map(Function <?super T,?extended U> mapper) 如果存在值,则将提供的映射函数应用于该值,如果结果为非null,则返回描述结果的Optional 。 |
10 | (T值)的static <T> Optional <T>, 返回具有指定的当前非空值的Optional。 |
11 | static <T> Optional <T> ofNullable(T value) 返回描述指定值的Optional,如果不为null,则返回空的Optional。 |
12 | T orElse(T other) 返回值(如果存在),否则返回other。 |
13 | T orElseGet(Supplier <?扩展T> other) 返回值(如果存在),否则调用other并返回该调用的结果。 |
14 | <X扩展Throwable> T orElseThrow(Supplier <?扩展X> exceptionSupplier) 返回所包含的值(如果存在),否则抛出要由提供的供应商创建的异常。 |
15 | StringtoString() 返回此Optional的非空字符串表示形式,适用于调试。 |
此类从以下类继承方法-
java.lang.Object
使用您选择的任何编辑器(例如,C:\> JAVA)创建以下Java程序。
import java.util.Optional; public class Java8Tester { public static void main(String args[]) { Java8Tester java8Tester = new Java8Tester(); Integer value1 = null; Integer value2 = new Integer(10); //Optional.ofNullable-允许传递的参数为null。 Optional<Integer> a = Optional.ofNullable(value1); //Optional.of-如果传递的参数为null,则抛出NullPointerException- Optional<Integer> b = Optional.of(value2); System.out.println(java8Tester.sum(a,b)); } public Integer sum(Optional<Integer> a, Optional<Integer> b) { //Optional.isPresent-检查值是否存在 System.out.println("First parameter is present: " + a.isPresent()); System.out.println("Second parameter is present: " + b.isPresent()); //Optional.orElse-返回值(如果存在),否则返回 //传递的默认值。 Integer value1 = a.orElse(new Integer(0)); //Optional.get-获取值,值应该存在 Integer value2 = b.get(); return value1 + value2; } }
使用javac编译器编译类,如下所示:
C:\JAVA>javac Java8Tester.java
现在运行Java8Tester,如下所示:
C:\JAVA>java Java8Tester
它应该产生以下输出-
输出结果
First parameter is present: false Second parameter is present: true 10
编译错误->[无法推断flatMap(函数>)的类型参数]
我正在解析输入JSON。对于一个字段,有3种可能: 字段不存在; 该值设置为NULL; 该值设置为有效值。 null
考虑一个和方法。我想将s映射到s并获得第一个。显而易见的解决方案是使用,但要求返回一个流,而没有方法(或者它是或提供一个方法将其转换为,或将其作为)查看。 我能想出的最好的办法是: 但这似乎是一个很普通的案例,但却显得太冗长了。谁有更好的主意?
我知道Optionals ifPresent()调用的目的是替换空检查。从Oracle文档中提取代码示例,它在简单情况下似乎非常有用。例如: 我只是想了解为什么这被认为比空检查更好。可读性?表演在我看来,这会对项目性能造成影响,因为必须引入一个新的对象才能容纳我们最终希望获得的对象?总之,为什么这是 如果(声卡!=null),则认为比这更好。
在Java8中,可以返回而不是。Java8文档说,可选的是“一个容器对象,它可以包含非空值,也可以不包含非空值。如果存在一个值,isPresent()将返回true,而get()将返回该值。” 在实践中,这为什么有用呢?另外,有没有使用作为首选项的情况?那表演呢?
我试图模拟一个对象,该对象返回一个带有Mockito的Java可选对象: 当被调用,它返回。 我希望方法返回 返回的任何原因? 方法如下: 以下是Junit:
在我的一些项目中,我经常使用do-thin-check NextForNull-getNext循环模式(不知道它是否有官方名称)。但是在Java8中,与检查客户端代码中的空引用相比,使用可选被认为是更干净的代码。但是当在这种循环模式中使用可选时,代码会变得有点冗长和丑陋,但是因为可选有一些方便的方法,我希望一定存在比我下面提出的更干净的方法。 示例: 考虑到下面的课程。 其中第一个项目的nr==1