Optional常用方法实例, 源码挺简单的,重要的是option 与 stream 以及lambda 的连贯使用

这篇具有很好参考价值的文章主要介绍了Optional常用方法实例, 源码挺简单的,重要的是option 与 stream 以及lambda 的连贯使用。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

Optional

static methods:

	Optional.ofNullable();
        Optional.empty();
        Optional.of();		

​ empty():

public static<T> Optional<T> empty() {
        @SuppressWarnings("unchecked")
        Optional<T> t = (Optional<T>) EMPTY;
        return t;
    //返回一个空的Optional
    }
    //等同于 Optional.of(null);

​ of()

// 非null 就继续执行 否则抛异常

 public static <T> Optional<T> of(T value) {
        return new Optional<>(Objects.requireNonNull(value));
    }

 public static <T> T requireNonNull(T obj) {
        if (obj == null)
            throw new NullPointerException();
        return obj;
    }

ofNullable()

 public static <T> Optional<T> ofNullable(T value) {
        return value == null ? (Optional<T>) EMPTY
                             : new Optional<>(value);
    }
    //与of 一致的原理 只是少去了抛异常

instance methods

​ get() //非null就get 否则异常

 public T get() {
        if (value == null) {
            throw new NoSuchElementException("No value present");
        }
        return value;
    }

isPresent 与 isEmpty

	public boolean isPresent() {
        return value != null;
    }
    public boolean isEmpty() {
        return value == null;
    }

ifPresent

public void ifPresent(Consumer<? super T> action) {
        if (value != null) {
            action.accept(value);
        }
    }

​ //lambada

 Optional<Integer> integer = Optional.ofNullable(12);
            integer.ifPresent(new Consumer<Integer>() {
                @Override
                public void accept(Integer integer) {
                }
            });
            integer.ifPresent((obj)->{
                System.out.println("进入执行操作");
                obj++;
            });
            System.out.println(integer.get()); // 12 

// 根据是否为NULL进行操作

public void ifPresentOrElse(Consumer<? super T> action, Runnable emptyAction) {
        if (value != null) {
            action.accept(value);
        } else {
            emptyAction.run();
        }
    }

//ifPresentOrElse 实例操作

      var ref = new Object() {
                Integer obj = 25;
            };
            Optional<Object> opt =  Optional.ofNullable(null);
            opt.ifPresentOrElse((i)->{
                System.out.println("不是空");
            },()->{
//                Variable used in lambda expression should be final or effectively final
                ref.obj = 25;
                System.out.println(ref.obj);
            });
            System.out.println(ref.obj);
        }

filter

public Optional<T> filter(Predicate<? super T> predicate) {
        Objects.requireNonNull(predicate);
        if (!isPresent()) {
            return this;
        } else {
            return predicate.test(value) ? this : empty();
        }
    }
//Predicate 是一个过滤条件  责任链模式 可以and or !等等

​ //filter进行以上对下进行输入 如果opt是一集合的话 , 无法进行筛选 , 只能使用集合本身进行filter

List<Integer> list = Arrays.asList(
                    Integer.parseInt("1"),
                    Integer.parseInt("123"),
                    Integer.parseInt("123123")
            );
            Optional<List<Integer>> opt = Optional.ofNullable(list);

            Stream<Integer> integerStream = list.stream().filter((val) -> {
                return val > 25;
            });
            System.out.println(integerStream.toList().toString());
            //            可以看到filter函数 携带stream流情况下 
//            以上级对下 边里内部属性
//            opt-> filter 的话 value是opt.get() 
//             如果内部进行筛选的话 ,会抛出异常   不允许进行remove  
//            currentModifyException
            opt.filter((var)->{
                System.out.println(var);
                return true;
            });

map()

public <U> Optional<U> map(Function<? super T, ? extends U> mapper) {
        Objects.requireNonNull(mapper);
        if (!isPresent()) {
            return empty();
        } else {
            return Optional.ofNullable(mapper.apply(value));
        }
    }

取到map

	                List<String> list = Arrays.asList(
                    new String("zs,123"),
                    new String("ls,123"),
                    new String("ww,123")
            );
            Optional<Object> objectStream = list.stream().findFirst().map(
                    (val)->{

                        return val.split("\\,")[0];
                    }
            );
            Stream<String> stringStream = list.stream().map((arr) -> {
                String result = "";
                for (int i = 0; i <arr.length(); i++) {
//                    arr. 可以看到arr 是无法进行get的 
//                    如果进行筛选 就不一整体为单位 容易失效
                    result += arr.toLowerCase();
                }
                return result;
            });
            System.out.println(stringStream.toList().toString());
            System.out.println(objectStream.get());

flatMap()

//与Map相似 多了个空处理
public <U> Optional<U> flatMap(Function<? super T, ? extends Optional<? extends U>> mapper) {
        Objects.requireNonNull(mapper);
        if (!isPresent()) {
            return empty();
        } else {
            @SuppressWarnings("unchecked")
            Optional<U> r = (Optional<U>) mapper.apply(value);
            return Objects.requireNonNull(r);
        }
    }

or()

//如果当前option value不为空 , 返回源对象, 否则返回新的对象
public Optional<T> or(Supplier<? extends Optional<? extends T>> supplier) {
        Objects.requireNonNull(supplier);
        if (isPresent()) {
            return this;
        } else {
            @SuppressWarnings("unchecked")
            Optional<T> r = (Optional<T>) supplier.get();
            return Objects.requireNonNull(r);
        }
    }

stream

public Stream<T> stream() {
        if (!isPresent()) {
            return Stream.empty();
        } else {
            return Stream.of(value);
        }
    }

orElse() // 根据是否为空判断

 public T orElse(T other) {
        return value != null ? value : other;
    }

orElseGet()// 集合Supplier

public T orElseGet(Supplier<? extends T> supplier) {
        return value != null ? value : supplier.get();
    }

orElseThrow() //是空就跑异常

public T orElseThrow() {
        if (value == null) {
            throw new NoSuchElementException("No value present");
        }
        return value;
    }

orElseThrow() //是空就抛出自定义异常文章来源地址https://www.toymoban.com/news/detail-748574.html

 public <X extends Throwable> T orElseThrow(Supplier<? extends X> exceptionSupplier) throws X {
        if (value != null) {
            return value;
        } else {
            throw exceptionSupplier.get();
        }
    }

equals

 public boolean equals(Object obj) {
        if (this == obj) {
            return true;
        }
        return obj instanceof Optional<?> other
                && Objects.equals(value, other.value);
    }

到了这里,关于Optional常用方法实例, 源码挺简单的,重要的是option 与 stream 以及lambda 的连贯使用的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Java 10 - Optional类新方法

    2024年02月13日
    浏览(21)
  • Lambda表达式与“::“方法引用 & 判空包装类Optional

    函数式接口(Functional Interface)就是有且仅有一个抽象方法,但是可以有多个非抽象方法的接口。 函数式接口可以被隐式转换为Lambda表达式。 方法引用主要是对Lambda表达式的一种优化! 方法引用的使用前提是对象和方法都是已经存在的! 方法引用提供了一种引用而不执行方

    2024年02月06日
    浏览(28)
  • Java 8及以上新特性:Lambda表达式、Stream API、Optional类与接口默认方法(四)

    目录 一、接口默认方法 1.1 概念解析: 1.2 应用场景: 1.3 使用注意事项: 1.4 使用示例: 二、结论 1.1 总结Java 8及以上版本四大新特性的重要意义与价值: 1.2 鼓励读者积极学习并运用这些新特性: 1.3 对未来Java版本可能引入的新特性进行展望: 1.1 概念解析: 接口默认方法

    2024年04月13日
    浏览(33)
  • [C++] std::optional与RVO:最高效的std::optional实践与探究

    在cppreference中,是这么介绍RVO的 In a return statement, when the operand is the name of a non-volatile object with automatic storage duration, which isn\\\'t a function parameter or a catch clause parameter, and which is of the same class type (ignoring cv-qualification) as the function return type. This variant of copy elision is known as NRVO, \\\"name

    2024年02月10日
    浏览(23)
  • Maven 中<optional>true</optional>和<scope>provided</scope>之间的区别

    依赖管理是maven提供的主要功能之一,无论我们需要什么依赖,只需将它们添加到 POM.xml 中,在构建或运行时所有必要的类和资源都会自动添加到项目的 classpath 中。 Maven 中的依赖是有传递(Transitive)性的,默认会包含传递的依赖,这样就不用手动引用每一个依赖了。比如下

    2024年02月06日
    浏览(24)
  • Optional使用详解

    在文章的开头,先说下NPE问题,NPE问题就是,我们在开发中经常碰到的NullPointerException.假设我们有两个类,他们的UML类图如下图所示 在这种情况下,有如下代码 这种写法,在user为null时,是有可能报NullPointerException异常的。为了解决这个问题,于是采用下面的写法 这种写法是

    2024年02月12日
    浏览(22)
  • maven optional

    optional是maven依赖jar时的一个选项,表示该依赖是可选的,不会被依赖传递。 减少不必要的依赖传递 减少jar包冲突 A项目的pom中依赖了system-local-api B项目依赖了A项目 因为maven有依赖传递机制,那么B项目就会有system-local-api的jar包,实际上在B项目中不一定要使用system-local-api,那

    2024年02月11日
    浏览(30)
  • Java Optional

    Optional 是 Java 8 中引入的一个类,用于处理可能为空的值。它提供了一种优雅的方式来避免空指针异常,并在值存在时进行处理。下面是一些 Optional 的常用方法: 创建 Optional 对象: Optional.empty() : 创建一个空的 Optional 对象。 Optional.of(value) : 创建一个包含指定非空值的 Optio

    2024年02月07日
    浏览(28)
  • Optional 类 - Java 8

    2023年04月18日
    浏览(25)
  • python中的Optional

    在Python的类型提示(type hinting)中, Optional  是一个特殊的类型,它表示某个值可以是特定类型,也可以是  None 。 Optional  通常用于描述函数参数、返回值或类属性的可能类型。 Optional  是  typing  模块的一部分,所以首先你需要导入它才能使用。 使用  Optional  的一个常

    2024年04月13日
    浏览(16)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包