zoukankan      html  css  js  c++  java
  • Optional类

    自己的理解  Optional类就像一个罩住对象的包装盒,可以装0或1个对象,提供简便的方式用来判断对象是否为空,并能针对对象的值做一些方便的处理,返回结果依然为Optional嵌套的对象.

    通过 of() 或者 ofNullable()将对象封装进Optional类.

    通过 get()方法将为null对象从Optional类中取出.

    Optional类是一个可以为null的容器对象.如果值存在则isPresent()方法会返回true,调用get()方法会返回该对象.

    Optional是个容器:它可以保存类型T的值,或者仅仅保存null.Optional提供很多有用的方法,这样我们就不用显示进行空值检测.

    Optional类的引入很好的解决了空指针异常.

    1.类声明

    以下是一个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> filter(Predicate<? super <T> predicate)

    如果值存在,并且这个值匹配给定的 predicate,返回一个Optional用以描述这个值,否则返回一个空的Optional。

    4 <U> Optional<U> flatMap(Function<? super T,Optional<U>> mapper)

    如果值存在,返回基于Optional包含的映射方法的值,否则返回一个空的Optional

    5 T get()

    如果在这个Optional中包含这个值,返回值,否则抛出异常:NoSuchElementException

    6 int hashCode()

    返回存在值的哈希码,如果值不存在 返回 0。

    7 void ifPresent(Consumer<? super T> consumer)

    如果值存在则使用该值调用 consumer , 否则不做任何事情。

    8 boolean isPresent()

    如果值存在则方法会返回true,否则返回 false。

    9 <U>Optional<U> map(Function<? super T,? extends U> mapper)

    如果有值,则对其执行调用映射函数得到返回值。如果返回值不为 null,则创建包含映射返回值的Optional作为map方法返回值,否则返回空Optional。

    10 static <T> Optional<T> of(T value)

    返回一个指定非null值的Optional。

    11 static <T> Optional<T> ofNullable(T value)

    如果为非空,返回 Optional 描述的指定值,否则返回空的 Optional。

    12 T orElse(T other)

    如果存在该值,返回值, 否则返回 other。

    13 T orElseGet(Supplier<? extends T> other)

    如果存在该值,返回值, 否则触发 other,并返回 other 调用的结果。

    14 <X extends Throwable> T orElseThrow(Supplier<? extends X> exceptionSupplier)

    如果存在该值,返回包含的值,否则抛出由 Supplier 继承的异常

    15 String toString()

    返回一个Optional的非空字符串,用来调试

  • 相关阅读:
    POJ 3356 水LCS
    POJ 2250 (LCS,经典输出LCS序列 dfs)
    POJ 1080( LCS变形)
    整数划分问题之最大乘积
    进程调度之FCFS算法(先来先运行算法)
    c模拟银行家资源分配算法
    c模拟内存分配算法(首次适应算法,最佳适应算法,最坏适应算法)
    HDU 2602 Bone Collector(经典01背包问题)
    NYOJ 44 字串和 (最大字串和 线性dp)
    匈牙利游戏(codevs 1269)
  • 原文地址:https://www.cnblogs.com/siran/p/10310330.html
Copyright © 2011-2022 走看看