hg: lambda/lambda/jdk: - fork the left child (or prefix) and compute with the right (or remaining).

paul.sandoz at oracle.com paul.sandoz at oracle.com
Tue Feb 12 05:34:59 PST 2013


Changeset: add7a96e56d3
Author:    psandoz
Date:      2013-02-12 14:29 +0100
URL:       http://hg.openjdk.java.net/lambda/lambda/jdk/rev/add7a96e56d3

- fork the left child (or prefix) and compute with the right (or remaining).
This works better for spliterators that are right balanced such as
an iterator from a spliterator, a spliterator from a ConcurrentLinkedQueue,
a spliterator from a Node that can mirror the tree of a source spliterator.
- for AbstractTask compute right children in a loop rather than recursively to avoid
potential stack overflows for right-balanced (or degenerate) trees.
Contributed-by: Doug Lea <dl at cs.oswego.edu>, Paul Sandoz <Paul.Sandoz at oracle.com>
- fix forEachUtil test to avoid potential resource issues such as OOME and
non-termination.

! src/share/classes/java/util/stream/AbstractShortCircuitTask.java
! src/share/classes/java/util/stream/AbstractTask.java
! test-ng/tests/org/openjdk/tests/java/util/stream/ForEachOpTest.java



More information about the lambda-dev mailing list