Tabulators -- a catalog
Remi Forax
forax at univ-mlv.fr
Fri Dec 28 06:39:28 PST 2012
On 12/28/2012 03:23 AM, Brian Goetz wrote:
> Here's a catalog of the currently implemented Tabulators.
[...]
> 3. Partition. Partitions a stream according to a predicate. Results
> always are a two-element array of something. Five forms:
>
> // Basic
> <T> Tabulator<T, Collection<T>[]>
> partition(Predicate<T> predicate)
>
> // Explicit factory
> <T, C extends Collection<T>> Tabulator<T, C[]>
> partition(Predicate<T> predicate,
> Supplier<C> rowFactory)
>
> // Partitioned mutable reduce
> <T, D> Tabulator<T, D[]>
> partition(Predicate<T> predicate,
> MutableReducer<T,D> downstream)
>
> // Partitioned functional reduce
> Tabulator<T, T[]>
> partition(Predicate<T> predicate,
> T zero,
> BinaryOperator<T> reducer)
>
> // Partitioned functional map-reduce
> Tabulator<T, T[]>
> partition(Predicate<T> predicate,
> T zero,
> Function<T, U> mapper,
> BinaryOperator<T> reducer)
You can't create an array of T (C, D) safely, so casting an array of
Object to an array of T is maybe acceptable if you control all the
access to that array like in collections, but here you export it.
Rémi
More information about the lambda-libs-spec-observers
mailing list