RXScala has three major building blocks or components to perform asynchronous stream programming—Observable, Subscription, and Observer:
data:image/s3,"s3://crabby-images/2eed1/2eed1fa8c4657c650f8f0d96309137900d669c89" alt=""
Here, we can observe the following things:
- Observable works as a producer; that means it emits the data
- Observer works as a consumer; that means it consumes the data
- Subscription works as a channel between Observable and Observer to emit and consume data through this channel
The following diagram shows the relationship between RxScala components and how they work with each other:
data:image/s3,"s3://crabby-images/8f6bd/8f6bded2c7be047a3a0f33c731112a65dfa55e22" alt=""
There are two more components to perform the asynchronous data stream processing:
- Subscriber
- Scheduler