To Stream.slice(fromInclusive, toExclusive) or Stream.slice(toSkip, limit) that is the question

Paul Sandoz paul.sandoz at oracle.com
Fri Oct 11 01:12:09 PDT 2013


Hi Joe,

I tend to think of slice(s, l) as the fused (optimal) form of skip(s).limit(l). For parallel streams the the fused form will result in less wrapping and/or buffering (depending on the properties of the input stream). Documentation-wise we should probably include an api note on skip and limit referring to slice in this respect.

Paul.

On Oct 11, 2013, at 3:28 AM, Joe Bowbeer <joe.bowbeer at gmail.com> wrote:

> slice(start, end) would be more useful and more consistent with its use in
> other languages (Python, Perl).
> 
> In Python, the elements are start .. end-1 whereas the end is inclusive in
> Perl.  But I think the use of start:end is fairly consistent for most
> implementations of slice.
> 
> I claim this would be more useful because otherwise there's no difference
> between slice and skip(start) + limit(end-start)
> 
> --Joe
> 
> 
> On Thu, Oct 10, 2013 at 5:04 PM, Brian Goetz <brian.goetz at oracle.com> wrote:
> 
>> FWIW, this is what the semantics were originally, and they got modified
>> to be consistent with substring() when we renamed slice to substring()
>> originally.  So this is a reversion to where we were before.
>> 
>> 
>> On 10/10/2013 7:54 PM, Mike Duigou wrote:
>> 
>>> Hello all;
>>> 
>>> In the review of the renaming patch for Stream.substream() -> slice()
>>> Brian asked me to consider also changing the semantics of the
>>> parameters from the current Stream.slice(fromInclusive,**toExclusive).
>>> The rationale is that we then have only one sense of usage in the
>>> parameters for skip/limit/slice. This also makes slice() more
>>> obviously equivalent to skip(toSkip).limit(limit). I am inclined to
>>> agree with him that using the same semantics for the parameters
>>> across the three methods has value.
>>> 
>>> I will go forward with changing to Stream.slice(toSkip,limit) before
>>> Monday assuming there is no outcry.
>>> 
>>> Mike
>>> 
>>> 



More information about the lambda-libs-spec-experts mailing list