• Java Optional orElse() 和 orElseGet() Optional.flatMap()和Optional.map()区别


    Java Optional 的 orElse() 和 orElseGet() 的区别

    1. 接收的参数不同

    orElse()方法以一个自定义类型的数据作为参数

    public T orElse(T t)
    

    orElseGet()方法以一个Supplier类型的数据作为参数

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

    2. 程序的执行过程不同

    以下面一段代码为例:

    public static void main(String[] args) {
        String[] names = new String[]{"zhang", "wang", "li", "zhao", "wu"};
        Optional.of("wang").orElse(getRandomName(names)); // 执行该句时会打印"Generating a name..."
        Optional.of("wang").orElseGet(() -> getRandomName(names));
    }
    
    public static String getRandomName(String[] names) {
        System.out.println("Generating a name...");
        Random random = new Random();
        return names[random.nextInt(5)];
    }
    

    在上述代码在运行Optional.of("wang").orElse(getRandomName(names))时会打印"Generating a name...",而在运行Optional.of("wang").orElseGet(() -> getRandomName(names))时没有任何输出,这说明了orElse()中的函数getRandomName被调用了,而orElseGet()中的Lambda表达式没有执行。

    产生上述现象的原因是,无论Optional对象中的值是否为空,orElse()函数都会执行;而由于orElseGet()中的参数为一个Supplier方法,该方法的特点是仅在必要的时候执行,因此只有在Optional对象中的值为空时,orElseGet()中的Supplier方法才会执行。

    3. 性能差异

    由于orElse()orElseGet()执行过程的差异,orElseGet()方法的执行效率相对而言也更快,这是因为他会跳过不必要的方法调用。

    因此,只有当默认值已经事先定义的情况下,才使用orElse(),否则使用orElseGet()更好

    =================================================================================

    使用map函数返回对象,使用flatMap返回Optional。例如:

    public static void main(String[] args) {
      Optional<String> s = Optional.of("input");
      System.out.println(s.map(Test::getOutput));
      System.out.println(s.flatMap(Test::getOutputOpt));
    }
    
    static Optional<String> getOutputOpt(String input) {
      return input == null ? Optional.empty() : Optional.of("output for " + input);
    }
    
    static String getOutput(String input) {
      return input == null ? null : "output for " + input;
    }
    

    这两个语句输出相同的东西。

  • 相关阅读:
    yarn 0.9.0 build spark
    redhat6.4上build storm 0.9.0.1
    redhat6.4安装storm集群-4节点
    Hadoop 2.2.0 4结点集群安装 非HA
    redhat6.4上安装mysql
    redhat6.4上用apache建立os repos
    Hive Over HBase
    Hadoop 2.2.0学习笔记20131210
    Hadoop 2.2.0学习笔记20131209
    IDH2.5.1. Pain Points
  • 原文地址:https://www.cnblogs.com/xichji/p/11689833.html
Copyright © 2020-2023  润新知