All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.infinispan.commons.api.functional.Traversable Maven / Gradle / Ivy

There is a newer version: 9.1.7.Final
Show newest version
package org.infinispan.commons.api.functional;

import org.infinispan.commons.util.Experimental;

import java.util.Comparator;
import java.util.Optional;
import java.util.function.BiConsumer;
import java.util.function.BiFunction;
import java.util.function.BinaryOperator;
import java.util.function.Consumer;
import java.util.function.Function;
import java.util.function.Predicate;
import java.util.function.Supplier;
import java.util.stream.Collector;

/**
 * Unsorted traversable stream for sequential and aggregating operations.
 *
 * 

Traversable contains two type of operations: *

    *
  1. Intermediate operations which transform a traversable, into another, * e.g. {@link #filter(Predicate)}. *
  2. *
  3. Terminal operations which produce a side effect, e.g. {@link #forEach(Consumer)}. * Once a terminal operation is completed, the resources taken by the * traversable are released. *
  4. *
* *

Traversable cannot be reused and hence is designed to be used only once * via its intermediate and terminal operations. * *

In distributed environments, unless individually specified, all lambdas * passed to methods are executed where data is located. For example, if * executing {@link #forEach(Consumer)}, the {@link Consumer} function is * executed wherever a particular key resides. To execute a for-each operation * where the side effects are executed locally, all the {@link Traversable}'s * data needs to be collected and iterated over manually. * * @param * @since 8.0 */ @Experimental public interface Traversable { /** * An intermediate operation that returns a traversable containing elements * matching the given predicate. */ Traversable filter(Predicate p); /** * An intermediate operation that returns a traversable containing the * results of applying the given function over the elements of the * traversable. */ Traversable map(Function f); /** * An intermediate operation that returns a traversable containing the * results of replacing each element of this traversable with the contents * of a traversable produced by applying the provided function to each element. * *

From a functional map perspective, this operation is particularly handy * when the values are collections. */ Traversable flatMap(Function> f); /** * A terminal operation that applies an operation to all elements of this * traversable. */ void forEach(Consumer c); /** * A terminal operation that applies a binary folding operation to a start * value and all elements of this traversable. */ T reduce(T z, BinaryOperator folder); /** * A terminal operation that applies a binary folding operation to all * elements of this traversable, and wraps the result in an optional. * If the traversable is empty, it returns an empty optional. */ Optional reduce(BinaryOperator folder); /** * A terminal operation that applies a binary folding operation to a start * value and the result of each element having a mapping function applied. * *

This is a combined map/reduce which could potentially be done more * efficiently than if a map is executed and then reduce. */ U reduce(U z, BiFunction mapper, BinaryOperator folder); /** * A terminal operation that transforms the traversable into a result * container, first constructed with the given supplier, and then * accumulating elements over it with the given consumer. * *

The combiner can be used to combine accumulated results executed in * parallel or coming from different nodes in a distributed environment. * *

In distributed environments where some keys are remote, the * {@link Supplier} and {@link BiConsumer} instances passed in are sent to * other nodes and hence they need to be marshallable. If the collect * operation can be defined using the helper methods in * {@link java.util.stream.Collectors}, it is recommended that those are * used, which can easily be made marshalled using the * {@code org.infinispan.stream.CacheCollectors#serializableCollector} method. */ R collect(Supplier s, BiConsumer accumulator, BiConsumer combiner); /** * A terminal operation that transforms the traversable into a result * container using a {@code Collector}. * *

In distributed environments where some keys are remote, the * {@link Collector} instance passed in is sent other nodes and hence it * needs to be marshallable. This can easily be made achieved using the * {@code org.infinispan.stream.CacheCollectors#serializableCollector} method. */ R collect(Collector collector); /** * A terminal operation that returns an optional containing the minimum * element of this traversable based on the comparator passed in. * If the traversable is empty, it returns an empty optional. */ default Optional min(Comparator comparator) { return reduce(BinaryOperator.minBy(comparator)); } /** * A terminal operation that returns an optional containing the maximum * element of this traversable based on the comparator passed in. * If the traversable is empty, it returns an empty optional. */ default Optional max(Comparator comparator) { return reduce(BinaryOperator.maxBy(comparator)); } /** * A terminal operation that returns the number of elements in the traversable. */ long count(); /** * A terminal operation that returns whether any elements of this * traversable match the provided predicate. * *

An important reason to keep this method is the fact as opposed * to a reduction which must evaluate all elements in the traversable, this * method could stop as soon as it has found an element that matches. */ boolean anyMatch(Predicate p); /** * A terminal operation that returns whether all elements of this * traversable match the provided predicate. * *

An important reason to keep this method is the fact as opposed * to a reduction which must evaluate all elements in the traversable, this * method could stop as soon as it has found an element that does not match * the predicate. */ boolean allMatch(Predicate p); /** * A terminal operation that returns whether no elements of this * traversable match the provided predicate. * *

An important reason to keep this method is the fact as opposed * to a reduction which must evaluate all elements in the traversable, this * method could stop as soon as it has found an element that does matches * the predicate. */ boolean noneMatch(Predicate predicate); /** * A terminal operation that returns an optional containing an element of * the traversable, or an empty optional if empty. */ Optional findAny(); }