-2

Java 8 Stream#findFirst() 是一个短路终端操作。这意味着一旦找到元素(通常与 filter() 操作一起使用),它将停止生成流。

但是,我想知道它是否会在 flatmap 创建的流上短路。即,它会使平面图操作中创建的流短路。

换句话说,哪个代码更有效(就在流中生成更少的元素而言):

示例 1(带有平面图):

    // produce range 0..99 (10 elements at a time)
    return IntStream.rangeClosed(0, 9)
        .flatMap(i -> IntStream.rangeClosed(i * 10, i * 10 + 9))
        .filter(i -> i == 55)
        .findFirst()
        .getAsInt();

示例 2(无平面图):

    // produce range 0..99 (all 100 elements at once)
    return IntStream.rangeClosed(0, 99)
        .filter(i -> i == 55)
        .findFirst()
        .getAsInt();
4

1 回答 1

1

答案是肯定的(使用 Java 11)

使用偷看:

示例 1(带有平面图):

    // produce range 0..99 (10 elements at a time)
    return IntStream.rangeClosed(0, 9)
        .flatMap(i -> IntStream.rangeClosed(i * 10, i * 10 + 9))
        .peek(System.out::println)
        .filter(i -> i == 55)
        .findFirst()
        .getAsInt();

示例 2(无平面图):

    // produce range 0..99 (all 100 elements at once)
    return IntStream.rangeClosed(0, 99)
        .peek(System.out::println)
        .filter(i -> i == 55)
        .findFirst()
        .getAsInt();

两者都生成了 56 个元素。(原本以为平面图是60。)

于 2019-04-20T02:14:42.697 回答