From 318a43864396540bf00c00b770a84d2d4376d2a7 Mon Sep 17 00:00:00 2001 From: Paul Sandoz Date: Mon, 26 Jan 2015 17:06:00 +0000 Subject: [PATCH] 8032513: The Spliterator characteristics CONCURRENT and IMMUTABLE are mutually exclusive Reviewed-by: chegar, lancea, dfuchs --- jdk/src/java.base/share/classes/java/util/Spliterator.java | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/jdk/src/java.base/share/classes/java/util/Spliterator.java b/jdk/src/java.base/share/classes/java/util/Spliterator.java index 324f9e0356c..96db12f0d60 100644 --- a/jdk/src/java.base/share/classes/java/util/Spliterator.java +++ b/jdk/src/java.base/share/classes/java/util/Spliterator.java @@ -553,6 +553,12 @@ public interface Spliterator { * sub-split size is known and additions or removals to the source are not * reflected when traversing. * + *

A top-level Spliterator should not report both {@code CONCURRENT} and + * {@code IMMUTABLE}, since they are mutually exclusive. Such a Spliterator + * is inconsistent and no guarantees can be made about any computation using + * that Spliterator. Sub-spliterators may report {@code IMMUTABLE} if + * additions or removals to the source are not reflected when traversing. + * * @apiNote Most concurrent collections maintain a consistency policy * guaranteeing accuracy with respect to elements present at the point of * Spliterator construction, but possibly not reflecting subsequent