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