Stream
A Stream is an Iterable-like structure that represents a source that can stream values when requested. The source is unspecified, it may be a materialized object (e.g. an Array), or a calculated sequence (e.g. the fibonacci numbers). However, unlike an Iterable, a Stream offers many methods to change the values produced by the Stream, before it is consumed, without the need to materialize intermediate instances.
Streams are reusable, immutable, and in general, they should always return the same values in the same order (exceptions are randomized streams). This makes them excellent to use as glue between various collection instances.
Except for intentionally random sources, a Stream should satisfy the following contract:
- An iterator produced by the Stream should return the same values in the same order.
Exports
The @rimbu/core package exports the following concrete Stream types:
| Name | Description | 
|---|---|
| Stream<T> | A possibly infinite sequence of elements of type T | 
Plumbing
The Stream should be seen as the way to transfer values from one form to the other. All Rimbu collections can be both converted to a Stream, and created from a Stream. Creating a Stream is always an O(1) operation.
Because a Stream has many methods to manipulate its values without materializing into a new collection, it can be used in many ways.
A Stream is also a TypeScript Iterable, so it also blends in well with 'traditional' methods and uses. Internally, a lot of effort is put into making it as efficient as possible using all kinds of optimizations. Many of its built-in methods will be much faster than using .forEach(...) or an iterating with for (const x of xs) {...}.