- This article is for people who know Rx programming,
Javascript
enthusiasts- Concepts covered in this paper:Responsive programming,NodeJs,Functional programming
background
I have been fascinated with Rx since I read an article from Info called functional Reactive Programming (FRP) : New Ideas for Real-time Interactive Application Development. Even at that time Rxjs library transplant a set of SUITABLE for Flash AS3.0 Rx library [ReactiveFl](ReactiveFl home page, document and download – Flash programming framework – open source Chinese community), but also in the actual development of continuous practice experience the fun. Recently, I accidentally saw a project named Callbag on Zhihu, which aroused my great interest. I even climbed over the wall to watch the author’s video Callback Heaven – Andre Staltz. After watching the video, I couldn’t calm down for a long time. However, when I ran the performance tests in the author’s code base, another unknown library appeared, called Most. This library has great performance, far more than any of its peers, and I wondered if I could combine the two to create an Rx library that has great performance, but is smart and easy to understand. So I tried the following:
Four implementations of RxJs
- Library with minimal implementation code (inspired by Callbag)
- Best performing library (refer to Most)
- Using the js generator implementation library (whim)
- A library that extends Nodejs’ Stream implementation (inspired by Event-Stream)
Inspired by the above, I have implemented Golang Rx library source code please follow my github, Langhuihui (Dexter)
Key features of Rx implementation
To implement an Rx library, the key lies in the realization of data push and consumption process of four basic functions:
- Subscribe: That is, activate each part of the Rx data stream, at which point producers can start sending data (some producers don’t care if someone subscribes)
- Sending/receiving data: a core function of production and consumption
- Completed/exception: An event emitted by the producer
- Unsubscribe: Triggered by the consumer to terminate the data stream and reclaim all resources
Producers (*) -- -- -- -- -- -- -- -- -- -- -- -- -- (o) -- -- -- -- -- -- -- -- -- -- -- -- -- -- (o) -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- (x) -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- - | > | | | | | Start value value error Done to consumers (*)-------------(o)--------------(o)---------------(x)----------------|> | | | | | Subscribe onNext onNext onError onCompleteCopy the code
In the above process, if the user calls the unSubscribe/Disopse method, it can be broken, and no more events are emitted
Two writing modes of Rx
- Chain programming
- Pipeline mode
Using the JS Proxy class, I have implemented a library to realize both writing modes. I will explain the principle in a later article. (To be continued)