- Hands-On Reactive Programming with Python
- Romain Picard
- 351字
- 2021-06-24 18:25:19
Functional reactive programming
The time has come to detail how to structure ReactiveX code in a functional way. It is tempting to name code designed this way functional reactive programming (FRP). Even though this name seems natural, it would be incorrectly named. FRP is something that was described by Conal Elliott in 1997 in a paper named Functional Reactive Animation. Functional reactive programming, as described by Conal Elliott, is composed of two types of values:
- Events that correspond to real events, or generated ones
- Behaviors that vary other continuous time
Events are the types of values that are implemented in ReactiveX observables. They can correspond to real events such as mouse location changes, some key presses on a keyboard, or a read operation that completes. Events are used to represent discrete values that change at specific times.
On the other hand, behaviors represent a value that is dependent on the time. So it is basically a formula, or a function, that is applied to the time. Behaviors always have a value, and they are used to represent continuous values depending on the current time. Behaviors are not available in ReactiveX. By the way, behaviors, as defined in the original paper, are available in no framework. This is due to the fact that the notion of a continuous value on a computer system does not exist. Some frameworks approximate behaviors by implementing them via sampling (that is, polling).
Since FRP is definitely not something that can be achieved with ReactiveX, writing functional code on top of a reactive framework should not be named FRP. However, with reactive programming and functional programming being more and more popular, and as they are more and more combined, this is often a source of confusion. The number of questions related to this on development discussion channels confirms this. Another similar name is used by several libraries: functional and reactive programming (FARP). The difference is both subtle and very clear: FARP is not FRP, but reactive code written in a functional way. This is the terminology that will be used in this book.
- FreeRTOS實時內核應用指南
- WordPress Mobile Web Development:Beginner's Guide
- 操作系統基礎與實踐:基于openEuler平臺
- VMware Horizon View 6 Desktop Virtualization Cookbook
- Extending Bootstrap
- Learning Bootstrap
- Mobile First Design with HTML5 and CSS3
- Android物聯網開發細致入門與最佳實踐
- Dreamweaver CS5.5 Mobile and Web Development with HTML5,CSS3,and jQuery
- AutoCAD 2014中文版從入門到精通
- NetDevOps入門與實踐
- Linux網絡操作系統項目教程(RHEL 7.4/CentOS 7.4)(第3版)(微課版)
- Agile IT Security Implementation Methodology
- CSS揭秘
- 每天5分鐘玩轉Docker容器技術