Operaciones intermedias con Streams: flatMap()

Avanzado
Java
Java
Actualizado: 12/03/2025

¡Desbloquea el curso completo!

IA
Ejercicios
Certificado
Entrar

La programación funcional en Java se introdujo con la versión 8 del lenguaje, que incorporó cambios significativos en la forma en que se pueden manipular y procesar datos. Entre estos cambios, se encuentra el API de Streams, que provee una serie de operaciones para trabajar con secuencias de datos de manera eficiente y declarativa.

¿Te está gustando esta lección?

Inicia sesión para no perder tu progreso y accede a miles de tutoriales, ejercicios prácticos y nuestro asistente de IA.

Progreso guardado
Asistente IA
Ejercicios
Iniciar sesión gratis

Más de 25.000 desarrolladores ya confían en CertiDevs

El concepto de Stream es fundamental para entender la programación funcional en Java. Un Stream representa una secuencia de elementos de un tipo particular y permite realizar operaciones en esta secuencia de manera declarativa. Estas operaciones pueden ser tanto intermedias como finales. Las operaciones intermedias son aquellas que transforman un Stream en otro Stream, mientras que las operaciones finales producen un resultado o un efecto secundario.

Entre las operaciones intermedias, flatMap() es una de las más útiles y versátiles. Para entender flatMap(), es esencial tener un conocimiento básico de otras operaciones intermedias, como map() y filter(), y de conceptos de programación funcional como las funciones lambda y los métodos referenciados. Esta explicación se centrará en la operación flatMap().

Función flatMap()

La función flatMap() es una operación intermedia que se utiliza para aplanar las estructuras de datos. Se llama 'flatMap' porque es una combinación de 'map' y 'flatten'.

El método map() transforma los elementos de un Stream mediante la aplicación de una función a cada elemento, mientras que flatten convierte una estructura de datos jerárquica (como una lista de listas) en una estructura de un solo nivel.

flatMap() combina estas dos operaciones: aplica una función a cada elemento de un Stream (como map()) y luego aplana el resultado en un nuevo Stream.

Sintaxis de flatMap()

La sintaxis básica de flatMap() en Java es la siguiente:

Stream<R> flatMap(Function<? super T,? extends Stream<? extends R>> mapper)

Esta es la firma del método flatMap(), donde T es el tipo de los elementos en el Stream original y R es el tipo de los elementos en el Stream resultante. mapper es una función que se aplica a cada elemento del Stream original y devuelve un Stream de elementos.

Ejemplos de flatMap()

Para entender cómo funciona flatMap(), es útil considerar algunos ejemplos.

Ejemplo 1: Transformar y aplanar una lista de listas

Supongamos que se tiene una lista de listas de números enteros:

List<List<Integer>> listOfLists = Arrays.asList(
    Arrays.asList(1, 2, 3), 
    Arrays.asList(4, 5, 6), 
    Arrays.asList(7, 8, 9)
);

Si se quiere transformar esta lista de listas en una lista plana de enteros, se podría utilizar flatMap() de la siguiente manera:

List<Integer> flatList = listOfLists.stream()
    .flatMap(list -> list.stream())
    .collect(Collectors.toList());

System.out.println(flatList);  // Output: [1, 2, 3, 4, 5, 6, 7, 8, 9]

Lo que ocurre aquí es que flatMap() toma cada lista interna y aplica la función list -> list.stream(), que transforma la lista en un Stream. Luego, flatMap() aplatana estos Streams en un solo Stream. Finalmente, collect() se usa para convertir el Stream en una lista.

Ejemplo 2: Transformar y aplanar un Stream de arrays

De manera similar, se puede usar flatMap() para aplanar un Stream de arrays. Supongamos que se tiene un Stream de arrays de strings:

Stream<String[]> streamOfArrays = Stream.of(
    new String[]{"a", "b", "c"}, 
    new String[]{"d", "e", "f"}, 
    new String[]{"g", "h", "i"}
);

Si se quiere transformar este Stream de arrays en un Stream plano de strings, se puede utilizar flatMap() de la siguiente manera:

Stream<String> flatStream = streamOfArrays.flatMap(Arrays::stream);

flatStream.forEach(System.out::println);  // Output: a, b, c, d, e, f, g, h, i

En este caso, flatMap() toma cada array y aplica la función Arrays::stream, que transforma el array en un Stream. Luego, flatMap() aplatana estos Streams en un solo Stream.

Conclusión

La operación flatMap() es una de las operaciones intermedias más potentes del API de Streams en Java. Permite transformar y aplanar estructuras de datos de manera eficiente y declarativa, lo que facilita la manipulación de datos en muchas situaciones. Aunque puede parecer un poco abstracta al principio, con un poco de práctica y experimentación, flatMap() puede convertirse en una herramienta invaluable para cualquier desarrollador de Java.

Aprendizajes de esta lección

  1. Aprender la sintaxis y funcionamiento de la función flatMap().
  2. Entender cómo se aplica una función a cada elemento de un Stream con flatMap().
  3. Aprender a transformar y aplanar estructuras de datos con flatMap().
  4. Ganar práctica con ejemplos de código utilizando flatMap().

Completa Java y certifícate

Únete a nuestra plataforma y accede a miles de tutoriales, ejercicios prácticos, proyectos reales y nuestro asistente de IA personalizado para acelerar tu aprendizaje.

Asistente IA

Resuelve dudas al instante

Ejercicios

Practica con proyectos reales

Certificados

Valida tus conocimientos

Más de 25.000 desarrolladores ya se han certificado con CertiDevs

⭐⭐⭐⭐⭐
4.9/5 valoración