diff --git a/src/share/classes/java/lang/Iterable.java b/src/share/classes/java/lang/Iterable.java index 8d46dbfe5ff5ad437778dd34d8adc22b14bf6546..fe9086f6874d0cbc6eaf646f6b939c4caad22602 100644 --- a/src/share/classes/java/lang/Iterable.java +++ b/src/share/classes/java/lang/Iterable.java @@ -26,6 +26,8 @@ package java.lang; import java.util.Iterator; import java.util.Objects; +import java.util.Spliterator; +import java.util.Spliterators; import java.util.function.Consumer; /** @@ -72,5 +74,30 @@ public interface Iterable { action.accept(t); } } + + /** + * Creates a {@link Spliterator} over the elements described by this + * {@code Iterable}. + * + * @implSpec + * The default implementation creates an + * early-binding + * spliterator from the iterable's {@code Iterator}. The spliterator + * inherits the fail-fast properties of the iterable's iterator. + * + * @implNote + * The default implementation should usually be overridden. The + * spliterator returned by the default implementation has poor splitting + * capabilities, is unsized, and does not report any spliterator + * characteristics. Implementing classes can nearly always provide a + * better implementation. + * + * @return a {@code Spliterator} over the elements described by this + * {@code Iterable}. + * @since 1.8 + */ + default Spliterator spliterator() { + return Spliterators.spliteratorUnknownSize(iterator(), 0); + } } diff --git a/src/share/classes/java/util/Collection.java b/src/share/classes/java/util/Collection.java index d42ba3e8a6e37e3d268c6ab658d41d169e6bb00e..17ab7347dc03c3249e19b468f72d4e120ec285e0 100644 --- a/src/share/classes/java/util/Collection.java +++ b/src/share/classes/java/util/Collection.java @@ -537,6 +537,7 @@ public interface Collection extends Iterable { * @return a {@code Spliterator} over the elements in this collection * @since 1.8 */ + @Override default Spliterator spliterator() { return Spliterators.spliterator(this, 0); } diff --git a/src/share/classes/java/util/ConcurrentModificationException.java b/src/share/classes/java/util/ConcurrentModificationException.java index 3683fb399cfde33ce6040c1f2da5ed10aab5f5be..d5256538f04c98e9511c40bafee70c20a456ace2 100644 --- a/src/share/classes/java/util/ConcurrentModificationException.java +++ b/src/share/classes/java/util/ConcurrentModificationException.java @@ -57,6 +57,7 @@ package java.util; * @author Josh Bloch * @see Collection * @see Iterator + * @see Spliterator * @see ListIterator * @see Vector * @see LinkedList diff --git a/test/java/util/Spliterator/SpliteratorCollisions.java b/test/java/util/Spliterator/SpliteratorCollisions.java index 604d90b9f208a07e0ceb380253e403396d2f0729..e40ef916d46f8090e0bd1deb4e24692f5ac0fa94 100644 --- a/test/java/util/Spliterator/SpliteratorCollisions.java +++ b/test/java/util/Spliterator/SpliteratorCollisions.java @@ -48,7 +48,6 @@ import java.util.Spliterator; import java.util.TreeSet; import java.util.function.Consumer; import java.util.function.Function; -import java.util.function.LongConsumer; import java.util.function.Supplier; import java.util.function.UnaryOperator; @@ -677,11 +676,11 @@ public class SpliteratorCollisions { private static Map toBoxedMultiset(Iterable c) { Map result = new HashMap<>(); - c.forEach((Consumer) e -> { - if (result.containsKey((T)e)) { - result.put((T)e, new HashableInteger(((HashableInteger)result.get(e)).value + 1, 10)); + c.forEach(e -> { + if (result.containsKey(e)) { + result.put(e, new HashableInteger(result.get(e).value + 1, 10)); } else { - result.put((T)e, new HashableInteger(1, 10)); + result.put(e, new HashableInteger(1, 10)); } }); return result; diff --git a/test/java/util/Spliterator/SpliteratorTraversingAndSplittingTest.java b/test/java/util/Spliterator/SpliteratorTraversingAndSplittingTest.java index d58c2b9d54475fea0aa616890c3fa993ded3eb9f..6da6214e1ca5081523052b117f95564fec1001f5 100644 --- a/test/java/util/Spliterator/SpliteratorTraversingAndSplittingTest.java +++ b/test/java/util/Spliterator/SpliteratorTraversingAndSplittingTest.java @@ -321,6 +321,21 @@ public class SpliteratorTraversingAndSplittingTest { db.addCollection( c -> new AbstractSortedSetImpl(c)); + class IterableWrapper implements Iterable { + final Iterable it; + + IterableWrapper(Iterable it) { + this.it = it; + } + + @Override + public Iterator iterator() { + return it.iterator(); + } + } + db.add("new Iterable.spliterator()", + () -> new IterableWrapper(exp).spliterator()); + // db.add("Arrays.asList().spliterator()",