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

Recent Posts

  • Eclipse JKube 1.7.0 is now available!
  • Eclipse JKube 1.6.0 is now available!
  • Develop cloud native Kubernetes Java applications on Okteto Cloud
  • How to check if an array contains duplicate values in JavaScript?
  • Build Kubernetes controllers with Fabric8 Kubernetes Client, Quarkus, and JKube

Categories

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

Archives

  • 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 - 2022 Marc Nuri