Generators

Sam Pullara sam at sampullara.com
Thu Jan 3 12:44:31 PST 2013


These look pretty reasonable to me. What is the motivation for ints()?

Sam

On Thu, Jan 3, 2013 at 11:49 AM, Brian Goetz <brian.goetz at oracle.com> wrote:

> I'm looking over our generators.  Currently we have:
>
>   repeat(T)
>   repeat(n, T)
>   repeatedly(Supplier<T>)
>   repeatedly(n, Supplier<T>)
>   iterate(T, UnaryOperator<T>)
>   cycle(Iterable)
>
> I'd like to pare this down a lot.  Paul and I have been discussing
> techniques for making limit() more efficient, at which point the first four
> can collapse to
>
>   generate(Supplier<T>)
>
> since you can simulate repeat(T) with generate(() -> T) and the limited
> versions with generate().limit().
>
> That leaves us with
>
>   iterate(T, UnaryOperator<T>)
>   cycle(Iterable)
>
> and I'm thinking cycle doesn't pull its weight either.  If we took that
> out, we'd be down to the pleasantly small set of:
>
>   generate(Supplier<T>)
>   iterate(T, UnaryOperator<T>)
>
> For integer generators, we have
>
>   range(from, to)
>
> and I think we should add
>
>   ints() -> sugar for range(0, MAX_INT)
>
> (Or should ints() be truly infinite, wrapping around?)
>
>
-------------- next part --------------
An HTML attachment was scrubbed...
URL: http://mail.openjdk.java.net/pipermail/lambda-libs-spec-experts/attachments/20130103/ad4f73ea/attachment.html 


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