响应式编程使用三个核心概念:数据流,函数式编程和异步观察。数据流 Data Streams:比如一个 Timer 每隔 1 秒发布一个数,这个数依次递增 。那么这个 Timer 就可以是一个发布者 Publisher。
响应式编程使用三个核心概念:数据流,函数式编程和异步观察。
区分一下指令时编程和函数式编程。指令式编程就是我们熟悉的 if else 一步一步来。而函数式编程则是把功能提出来,不和数据本身的类型挂钩。比如 Filter 函数,就是筛选满足某种条件的数据。而响应式编程是什么呢?其实是对数据的处理,处理后发送给订阅者。
因此你也可以理解成响应式编程是对数据做出反馈,而这里判断数据的时候就用到了函数式编程的思想。为什么响应式编程使用了函数式编程的核心思想呢?主要是因为函数式编程是 Stateless 的,因此不会有副作用。而响应式编程想处理的就是数据流,所以也有人把响应式编程叫做数据流编程。
「响应式」这三个字描述的是我们的对数据流的处理方式,对数据变化作出响应。「函数式」指的是处理数据的编程方法,描述你想保留删选或者如何变更数据。「函数式」是「描述式」编程的一种体现。
这里我觉得苹果 Combine 响应式框架的解释很好,放在这里你感受一下。
The Combine framework provides a declarative Swift API for processing values over time. These values can represent many kinds of asynchronous events. Combine declares publishers to expose values that can change over time, and subscribers to receive those values from the publishers.
我大概翻译一下:Combine 框架提供了描述式 API 用以处理数据流。这些数据可以代表多种异步事件。Combine 框架使用 Publisher 来讲数据变更呈现出来;Subscriber 负责从发布者那里接受数据。
Combine 框架和 RxJava, RxJS, RxSwift 等一些列响应式框架和原理是一样的,因此你可以远离互通。下面的这些函数就是 Combine 框架 Publisher 函数的一些范例,你也可以把这些处理数据的函数叫做「函数式编程」。
延伸阅读:
分布式网络系统中,各个参与方节点的运行是相互独立的,没有共享内存,没有全局时钟。各节点通过消息来进行沟通。在传统的理念中,我们会把这样的网络根据他们通信方式描述成同步和异步的。
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系邮箱:hopper@cornerstone365.cn 处理,核实后本网站将在24小时内删除。