Spliterator
Doug Lea
dl at cs.oswego.edu
Wed Dec 19 06:38:31 PST 2012
On 12/19/12 09:19, Brian Goetz wrote:
> We use split() to build a tree of splits; this is mirrored by a tree of FJTs. I
> use this information to determine when split() is creating a new level of the
> tree, and when it is creating a new sibling at the same level.
>
> T firstChild = makeChild(spliterator.split());
> setPendingCount(naturalSplits);
> numChildren = naturalSplits + 1;
> children = firstChild;
> T curChild = firstChild;
> for (int i=naturalSplits-1; i >= 0; i--) {
> T newChild = makeChild((i > 0) ? spliterator.split() :
> spliterator);
> curChild.nextSibling = newChild;
> curChild = newChild;
> }
>
I'm trying hard to see the context or spec wording that
would make this useful.
Each time you call s.split, some fraction of s is split off.
So it seems that the value you want here is something like:
"return the number of times to split before you are logically
at the next depth level, if such a level exists"?
Which will be hard to state clearly.
Do you have any existing examples of Spliterators that
return values other than 1/0? That might help.
> The point is: I see value to the possibility of arranging spliterators in other
> than a binary tree.
No, nothing (explicitly) about binary trees, only about
supporting an incremental usage model.
As in: split; maybe split some more; ...
-Doug
More information about the lambda-libs-spec-observers
mailing list