Transforming Data with Java 8 Streams API: Difference between revisions

From NovaOrdis Knowledge Base
Jump to navigation Jump to search
Line 14: Line 14:


<syntaxhighlight lang='java'>
<syntaxhighlight lang='java'>
<R> Stream<R> map(Function<? super T, ? extends R> mapper);
public interface Stream<T> {
    ...
    <R> Stream<R> map(Function<? super T, ? extends R> mapper);
    ...
}
</syntaxhighlight>
</syntaxhighlight>



Revision as of 18:12, 28 March 2018

Internal

Overview

The Stream API offers the possibility to intercept a stream and converts its elements into elements of another type, offered also as a stream. This operations is conventionally named mapping. The world mapping is used because it has a meaning similar to transforming, but with the nuance of "creating a new version" rather than "modifying".

Mapping Data

https://docs.oracle.com/javase/10/docs/api/java/util/stream/Stream.html#flat(java.util.function.Function)

The Stream API exposes the map() method, which converts the stream's elements into elements of another type, offered also as a stream. The conversion if performed by a Function<T, R> presented as the argument of the map() method.

public interface Stream<T> {
    ...
    <R> Stream<R> map(Function<? super T, ? extends R> mapper);
    ...
}

Flat-Mapping Data

flatMap()

flatMap() returns a stream consisting of the results of replacing each element of this stream with the contents of a mapped stream produced by applying the provided mapping function to each element. Each mapped stream is closed after its contents have been placed into this stream. If a mapped stream is null an empty stream is used, instead.

https://docs.oracle.com/javase/10/docs/api/java/util/stream/Stream.html#flatMap(java.util.function.Function)
<R> Stream<R> flatMap(Function<? super T,? extends Stream<? extends R>> mapper)

Example:

List<String> uniqueChars = words.
    stream().
    map(word -> word.split("")).
    flatMap(Arrays::stream).
    distinct().
    collect(toList());