A logo showing the text blog.marcnuri.com
Español
Home»Java»How to convert an Iterator or Spliterator to Stream

Recent Posts

  • Fabric8 Kubernetes Client 6.5.0 is now available!
  • Eclipse JKube 1.11 is now available!
  • Fabric8 Kubernetes Client 6.4.1 is now available!
  • I bought an iPad
  • Three years at Red Hat

Categories

  • Front-end
  • Java
  • JavaScript
  • Legacy
  • Operations
  • Personal
  • Pet projects
  • Tools

Archives

  • March 2023
  • February 2023
  • January 2023
  • December 2022
  • November 2022
  • October 2022
  • September 2022
  • August 2022
  • July 2022
  • June 2022
  • May 2022
  • February 2022
  • January 2022
  • December 2021
  • November 2021
  • October 2021
  • September 2021
  • August 2021
  • July 2021
  • January 2021
  • December 2020
  • November 2020
  • October 2020
  • September 2020
  • August 2020
  • July 2020
  • June 2020
  • May 2020
  • December 2019
  • October 2019
  • September 2019
  • July 2019
  • March 2019
  • November 2018
  • July 2018
  • June 2018
  • May 2018
  • April 2018
  • March 2018
  • February 2018
  • December 2017
  • July 2017
  • December 2015
  • November 2015
  • November 2008
  • November 2007
  • September 2007
  • August 2007
  • July 2007
  • June 2007
  • May 2007
  • April 2007
  • March 2007

How to convert an Iterator or Spliterator to Stream

2021-10-09 in Java tagged Java / Java 8 / Streams by Marc Nuri | Last updated: 2021-10-09
Versión en Español

In this short post I'll show you how to use the StreamSupport utility class introduced in Java 8 to convert a Spliterator or an Iterator to a Stream.

How to convert a Spliterator to a Stream?

The StreamSupport class introduces the stream method which creates a new parallel or sequential stream from the provided Stream. We can take advantage of this method to easily convert the Spliterator into a Stream.

1final var input = Arrays.asList(2, 3, 5, 7, 11).spliterator();
2StreamSupport.stream(input, false)
3  .filter(i -> i % 2 == 0)
4  .forEach(System.out::println);

In the previous snippet, I'm converting an array of integers into a Spliterator (line 1). You wouldn't usually do this, since you can directly stream that array (this is just for demo purposes). You would usually end up with a Spliterator instance by consuming a method that returns a value that implements the Spliterator interface.

The second argument in the StreamSupport#stream method (line 2), specifies if the produced stream should be processed in parallel or sequentially. By default, Java processes streams sequentially, it's up to you to switch to parallel in case your pipeline supports it and you can take advantage of it.

If we execute the previous snippet, the console will show the following output:

2

How to convert an Iterator to a Stream?

Now that I've showed you how to go from a Spliterator to a Stream, I can show you how to achieve the same with an Iterator. The trick here is to convert the Iterator to a Spliterator first, and then repeat the process I described before.

1final var iterator = Arrays.asList(2, 3, 5, 7, 11).iterator();
2final var input = Spliterators.spliteratorUnknownSize(iterator, Spliterator.ORDERED);
3StreamSupport.stream(input, false)
4  .filter(i -> i % 2 == 0)
5  .forEach(System.out::println);

In the previous snippet, I'm using the Spliterators#spliteratorUnknownSize method (line 2) to convert the Iterator. This provides me with the Spliterator instance that can be processed just like before.

References

  • java.util.stream.StreamSupport Javadoc
  • java.util.Spliterators Javadoc
Twitter iconFacebook iconLinkedIn iconPinterest iconEmail icon

Post navigation

← How to generate a serialVersionUID in IntelliJ IDEAcURL: DELETE request examples →
© 2007 - 2023 Marc Nuri