011.理解事件(events)和流(streams)

2024-05-15 03:44
文章标签 理解 事件 events 011 streams

本文主要是介绍011.理解事件(events)和流(streams),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在软件系统中,事件是一种用于指示发生了什么事情的消息。该事件可能代表一个技术事件——例如,在GUI应用程序中,您可能会在按下的每个键或每次鼠标移动上看到事件。该事件还可以表示业务发生,例如在金融系统中完成的货币交易。

事件由事件源引发,并由事件处理程序使用。正如您所看到的,事件是表示时变值的一种方式。在Rx中,事件源可以由可观察的表示,事件处理程序可以由观察者表示。但是,我们的应用程序正在使用的简单数据呢,比如数据库中的数据或从web服务器获取的数据。它在被动世界中有一席之地吗?

一、一切都是“流”
您编写的应用程序最终将处理某种数据,如图1.15所示。数据可以有两种类型:静止数据和运动数据。
在这里插入图片描述
图1.15运动数据和静止数据作为一个数据流。来自外部环境的连接点非常适合创建可观察性。这些可观测值可以很容易地与Rx合并,以创建合并的可观测值,内部模块可以在不知道数据元素的确切来源的情况下订阅该可观测值。

静态数据以数字格式存储,通常从数据库或文件等持久存储中读取。运动中的数据在网络(或其他介质)上移动,并被推送到您的应用程序或由您的应用从任何外部源提取。

无论您在应用程序中使用何种类型的数据,都应该明白,一切都可以作为流来观察,甚至是静止的数据和对应用程序来说看起来静态的数据。例如,配置数据被认为是静态的,但即使在某个时刻,配置也会发生变化,无论是在长时间还是短时间之后。从应用程序的角度来看,这并不重要;你想被动应对,并在这些变化发生时处理它们。当您将静止的数据视为另一个数据流时,可以更容易地组合这两种类型的数据。对于您的应用程序来说,数据来自何处并不重要。

例如,应用程序启动通常从其持久存储加载数据以恢复其状态(应用程序关闭前保存的状态)。当然,在应用程序运行过程中,这种状态可能会发生变化。应用程序的内部关心状态的部分可以查看承载它的数据流。当应用程序启动时,流将传递加载的数据,当状态发生变化时,流会承载更新。

我喜欢用一个很好的比喻来解释流,那就是水管,但这个水管有数据包穿过它,就像你在图1.16中看到的那样。当使用水管时,你可以用它做很多事情。你可以在末端安装过滤器。可以添加不同的软管头,以提供不同的功能。您可以添加压力监测器来帮助调节流量。您可以对数据流执行同样的操作。你会想要建立一个管道,让信息在其中流动,最终给出适合你逻辑的最终结果;这包括过滤、转换、分组、合并等等。

数据流和事件流非常适合Rx可观察性。使用IObservable对它们进行抽象使您能够合成运算符并创建复杂的执行管道。这与您对Shoppy示例所做的类似,在Shoppy示例中,对服务器的调用作为更复杂的执行管道的一部分获得了折扣,该管道还使用了过滤(在连接上)并最终刷新了视图(就像洒水喷头泼水一样)。

在这里插入图片描述
图1.16数据流就像一根软管:每一滴水都是一个数据包,需要经过各个站点,直到到达终点。您的数据还需要进行过滤和转换,直到它到达真正的处理程序,并对其进行有用的处理。

——未完待续

译者:重庆教主(QQ23611316) 2024.05.14

网站:WPF中文网 wpfsoft.com

这篇关于011.理解事件(events)和流(streams)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/990713

相关文章

Java Spring的依赖注入理解及@Autowired用法示例详解

《JavaSpring的依赖注入理解及@Autowired用法示例详解》文章介绍了Spring依赖注入(DI)的概念、三种实现方式(构造器、Setter、字段注入),区分了@Autowired(注入... 目录一、什么是依赖注入(DI)?1. 定义2. 举个例子二、依赖注入的几种方式1. 构造器注入(Con

深入理解Go语言中二维切片的使用

《深入理解Go语言中二维切片的使用》本文深入讲解了Go语言中二维切片的概念与应用,用于表示矩阵、表格等二维数据结构,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来一起学习学习吧... 目录引言二维切片的基本概念定义创建二维切片二维切片的操作访问元素修改元素遍历二维切片二维切片的动态调整追加行动态

从原理到实战深入理解Java 断言assert

《从原理到实战深入理解Java断言assert》本文深入解析Java断言机制,涵盖语法、工作原理、启用方式及与异常的区别,推荐用于开发阶段的条件检查与状态验证,并强调生产环境应使用参数验证工具类替代... 目录深入理解 Java 断言(assert):从原理到实战引言:为什么需要断言?一、断言基础1.1 语

spring IOC的理解之原理和实现过程

《springIOC的理解之原理和实现过程》:本文主要介绍springIOC的理解之原理和实现过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、IoC 核心概念二、核心原理1. 容器架构2. 核心组件3. 工作流程三、关键实现机制1. Bean生命周期2.

Python开发文字版随机事件游戏的项目实例

《Python开发文字版随机事件游戏的项目实例》随机事件游戏是一种通过生成不可预测的事件来增强游戏体验的类型,在这篇博文中,我们将使用Python开发一款文字版随机事件游戏,通过这个项目,读者不仅能够... 目录项目概述2.1 游戏概念2.2 游戏特色2.3 目标玩家群体技术选择与环境准备3.1 开发环境3

Spring Boot 整合 SSE的高级实践(Server-Sent Events)

《SpringBoot整合SSE的高级实践(Server-SentEvents)》SSE(Server-SentEvents)是一种基于HTTP协议的单向通信机制,允许服务器向浏览器持续发送实... 目录1、简述2、Spring Boot 中的SSE实现2.1 添加依赖2.2 实现后端接口2.3 配置超时时

深入理解Apache Kafka(分布式流处理平台)

《深入理解ApacheKafka(分布式流处理平台)》ApacheKafka作为现代分布式系统中的核心中间件,为构建高吞吐量、低延迟的数据管道提供了强大支持,本文将深入探讨Kafka的核心概念、架构... 目录引言一、Apache Kafka概述1.1 什么是Kafka?1.2 Kafka的核心概念二、Ka

C#如何动态创建Label,及动态label事件

《C#如何动态创建Label,及动态label事件》:本文主要介绍C#如何动态创建Label,及动态label事件,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录C#如何动态创建Label,及动态label事件第一点:switch中的生成我们的label事件接着,

spring @EventListener 事件与监听的示例详解

《spring@EventListener事件与监听的示例详解》本文介绍了自定义Spring事件和监听器的方法,包括如何发布事件、监听事件以及如何处理异步事件,通过示例代码和日志,展示了事件的顺序... 目录1、自定义Application Event2、自定义监听3、测试4、源代码5、其他5.1 顺序执行

深入理解Apache Airflow 调度器(最新推荐)

《深入理解ApacheAirflow调度器(最新推荐)》ApacheAirflow调度器是数据管道管理系统的关键组件,负责编排dag中任务的执行,通过理解调度器的角色和工作方式,正确配置调度器,并... 目录什么是Airflow 调度器?Airflow 调度器工作机制配置Airflow调度器调优及优化建议最