ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

rxjs Observable 设计原理背后的 Pull 和 Push 思路

2022-05-24 09:05:11  阅读:155  来源: 互联网

标签:Observable 消费者 Pull 拉取 rxjs Push 数据


Observables 顾名思义,是可以被观察的事务。在 Rxjs 的上下文里,Observable 会随着时间的推移,在某个时间点产生数据。

Observables 可以:

  • 不停地(永远)产生值,比如 interval 操作符。
  • 可以一次性生产价值,然后进入 complete 状态。
  • 可能会产生错误,然后进入 complete 状态。

Observable 是一种异步事件的实现利器,例如单个操作(HTTP 请求)或多个可重复的操作(例如光标移动或按键)。

响应式编程(Reactive Programming)是一种构建应用程序的方法,它对应用程序内发生的变化做出响应,而不是编写应用程序来处理这些变化。后者是 Imperative Programming 即命令式编程的典型特征。

要理解 Observable 的设计原理,我们首先有必要了解典型的生产者和消费者通信的几种模式。

拉取(Pull)和推送(Push)模型定义了数据生产者如何与数据消费者合作。

Pull

拉取:在拉取模型的情况下,消费者决定何时使用或请求数据。 当我们创建一个返回值的函数时,该函数就是生产者。 但是,在调用该函数(或要求提供数据)之前,该函数不会产生任何内容。

调用函数的代码是消费者。 此调用按照消费者的需求被触发。 消费者决定传播策略。

Push

推送:生产者主导推模型。 任何使用数据的人都不知道数据何时到达。 他们知道数据到达时要做的应用逻辑,但消费者不决定数据何时到达。

Promise 是推送模型的经典示例。 当任务完成时,promise 会产生数据或错误。 传递给 Promise 的回调函数永远不会知道 Promise 何时完成,它只负责数据成功达到或者发生错误时,应该执行什么样的逻辑。

标签:Observable,消费者,Pull,拉取,rxjs,Push,数据
来源: https://www.cnblogs.com/sap-jerry/p/16304195.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有