Reactive编程:什么是Reactive编程?Reactive编程思想

在这里插入图片描述

文章目录

  • **1. Reactive编程概述**
    • **1.1 什么是Reactive编程?**
      • **1.1.1 Reactive编程的定义**
      • **1.1.2 Reactive编程的历史**
      • **1.1.3 Reactive编程的应用场景**
      • **1.1.4 Reactive编程的优势**
    • **1.2 Reactive编程的核心思想**
      • **1.2.1 响应式(Reactive)**
      • **1.2.2 异步(Asynchronous)**
      • **1.2.3 非阻塞(Non-blocking)**
      • **1.2.4 Reactive宣言(The Reactive Manifesto)**
    • **小结**

在这里插入图片描述


1. Reactive编程概述

1.1 什么是Reactive编程?

在这里插入图片描述

1.1.1 Reactive编程的定义

Reactive编程(响应式编程)是一种面向数据流(Data Stream)变化传播(Change Propagation)的编程范式,它强调系统能够对数据变化做出即时响应,并以异步非阻塞的方式处理数据流。

Reactive编程的核心在于:

  • 数据流驱动:程序逻辑围绕数据流构建,而不是传统的控制流(如顺序执行、循环、条件判断)。
  • 事件驱动:系统对事件(如用户输入、网络请求、传感器数据)做出反应,而不是主动轮询。
  • 声明式编程:开发者关注“做什么”而非“如何做”,代码更简洁、易维护。

1.1.2 Reactive编程的历史

Reactive编程并非全新概念,其思想可追溯至:

  • 1970年代:函数式编程(如Haskell、Lisp)中的惰性求值(Lazy Evaluation)高阶函数(Higher-Order Functions)
  • 1980年代:电子表格(如Excel)中的单元格依赖计算,数据变化自动触发更新。
  • 2000年代:微软推出Reactive Extensions(Rx),将Reactive编程引入主流开发(Rx.NET → RxJava/RxJS)。
  • 2010年代Reactive Streams规范(2015)标准化背压(Backpressure)管理,Spring推出WebFlux,推动Reactive在微服务架构中的应用。

1.1.3 Reactive编程的应用场景

Reactive编程适用于:

  1. 高并发、低延迟系统(如金融交易、实时游戏)。
  2. 大数据流处理(如Kafka、Spark Streaming)。
  3. 前端UI交互(如React/Vue的响应式状态管理)。
  4. IoT(物联网)(传感器数据实时处理)。
  5. 微服务通信(异步消息驱动架构)。

1.1.4 Reactive编程的优势

特性传统编程Reactive编程
并发模型同步阻塞(线程池)异步非阻塞(事件循环)
资源占用高(每个请求一个线程)低(少量线程处理大量请求)
响应速度依赖线程池大小即时响应(无阻塞等待)
代码复杂度回调地狱(Callback Hell)链式调用(可读性高)
扩展性垂直扩展(加服务器)水平扩展(弹性伸缩)

1.2 Reactive编程的核心思想

在这里插入图片描述

1.2.1 响应式(Reactive)

定义:系统能够对数据流的变化外部事件做出即时响应。

关键特性

  1. 事件驱动(Event-Driven)
    • 例如:用户点击按钮 → 触发数据流 → UI自动更新。
    • 代码示例(RxJS):
      button.addEventListener('click', (event) => {console.log('Button clicked!');
      });
      
  2. 数据流(Data Stream)
    • 所有数据(变量、用户输入、HTTP响应)都被视为时间序列上的事件流
    • 示例:鼠标移动轨迹可以表示为坐标流 (x1,y1), (x2,y2), ...
  3. 自动依赖跟踪
    • 类似Excel公式,当输入数据变化时,依赖它的计算自动更新。
    • 代码示例(Vue.js):
      const state = reactive({ count: 0 });
      watch(() => state.count, (newVal) => {console.log(`Count changed to ${newVal}`);
      });
      

1.2.2 异步(Asynchronous)

定义:操作不会阻塞程序执行,而是通过回调、Promise或流处理结果。

与传统同步代码对比

场景同步代码Reactive异步代码
HTTP请求阻塞线程直到响应返回立即返回,响应到达时通知
文件读取线程等待I/O完成注册回调,I/O完成后触发

异步编程模型演进

  1. 回调函数(Callback) → 回调地狱(Callback Hell)
    fs.readFile('file1.txt', (err, data1) => {fs.readFile('file2.txt', (err, data2) => {// 嵌套层级深,难以维护});
    });
    
  2. Promise → 链式调用,但仍需.then()
    fetch('/api/data').then(response => response.json()).then(data => console.log(data));
    
  3. Reactive Streams(Observable) → 更强大的流操作
    Flux.fromIterable(list).filter(item -> item.startsWith("A")).subscribe(System.out::println);
    

1.2.3 非阻塞(Non-blocking)

定义:线程不会因等待I/O(如数据库查询、网络请求)而闲置,而是继续处理其他任务。

实现机制

  1. 事件循环(Event Loop)
    • 如Node.js、Netty的Reactor模式。
    • 单线程处理多任务,通过事件队列调度。
  2. NIO(Non-blocking I/O)
    • Java的Selector、Go的goroutine
  3. 背压(Backpressure)
    • 消费者控制数据流速度,避免生产者过快导致内存溢出。

示例:阻塞 vs 非阻塞

// 阻塞式(传统Java)
Socket socket = new Socket("example.com", 80);
InputStream in = socket.getInputStream(); // 线程卡住直到数据到达// 非阻塞式(Reactive)
Mono<String> response = WebClient.create().get().uri("http://example.com").retrieve().bodyToMono(String.class); // 立即返回Mono,数据到达时异步处理

1.2.4 Reactive宣言(The Reactive Manifesto)

2014年提出的Reactive系统四大原则:

  1. 即时响应(Responsive):系统快速响应用户请求。
  2. 弹性(Resilient):故障隔离,自动恢复。
  3. 可伸缩(Elastic):根据负载动态扩展。
  4. 消息驱动(Message-Driven):组件通过异步消息通信。

小结

  • Reactive编程是通过数据流异步非阻塞架构构建高响应性系统的范式。
  • 核心思想:响应式(自动响应变化)、异步(非阻塞处理)、数据流(事件序列)。
  • 适用场景:实时系统、高并发微服务、大数据处理等。
  • 演进趋势:从回调→Promise→Reactive Streams,未来与RSocket、协程等结合更紧密。

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/42486.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【数学建模】动态规划算法(Dynamic Programming,简称DP)详解与应用

动态规划算法详解与应用 文章目录 动态规划算法详解与应用引言动态规划的基本概念动态规划的设计步骤经典动态规划问题1. 斐波那契数列2. 背包问题3. 最长公共子序列(LCS) 动态规划的优化技巧动态规划的应用领域总结 引言 动态规划(Dynamic Programming&#xff0c;简称DP)是一…

Linux基础之软硬链接

参考链接&#xff1a;https://baijiahao.baidu.com/s?id1770724291436944734&wfrspider&forpc 一、定义 1.硬链接&#xff08;Hard Link&#xff09; 硬链接是指多个文件名指向同一个物理文件的链接关系。它们在文件系统中具有相同的inode号&#xff08;索引节点号…

python每日十题(13)

一般把计算机完成一条指令所花费的时间称为一个指令周期。指令周期越短&#xff0c;指令执行就越快。本题答案为D选项。 顺序程序具有顺序性、封闭性和可再现性的特点&#xff0c;使得程序设计者能够控制程序执行的过程(包括执行顺序、执行时间&#xff09;&#xff0c;对程序执…

0328-内存图2

是否正确待定&#xff1a; Perso类 package com.qc.内存图2;public class Perso {public int age;public String name;public static int flag;public void m1() {}public static void m2() {}Overridepublic String toString() {return "Perso [age" age "…

Java 开发中的 AI 黑科技:如何用 AI 工具自动生成 Spring Boot 项目脚手架?

在 Java 开发领域&#xff0c;搭建 Spring Boot 项目脚手架是一项耗时且繁琐的工作。传统方式下&#xff0c;开发者需要手动配置各种依赖、编写基础代码&#xff0c;过程中稍有疏忽就可能导致配置错误&#xff0c;影响开发进度。如今&#xff0c;随着 AI 技术的迅猛发展&#x…

一文详解k8s体系架构知识

0.云原生 1.k8s概念 1. k8s集群的两种管理角色 Master&#xff1a;集群控制节点&#xff0c;负责具体命令的执行过程。master节点通常会占用一股独立的服务器&#xff08;高可用部署建议用3台服务器&#xff09;&#xff0c;是整个集群的首脑。 Master节点一组关键进程&#xf…

ubuntu下docker 安装 graylog 6.1

下载docker compose相关仓库 https://github.com/Graylog2/docker-compose 按readme所述&#xff0c;拷贝.env.example并重命名 .env 按.env中的说明创建密码和密钥 创建GRAYLOG_PASSWORD_SECRET 用: pwgen -N 1 -s 96 创建GRAYLOG_ROOT_PASSWORD_SHA2 用: echo -n yourpa…

创新驱动 智领未来丨中威电子全景展示高速公路数字化创新成果

在数字经济与新型基础设施建设深度融合的背景下&#xff0c;中国智慧交通产业正迎来前所未有的发展机遇。3月27日&#xff0c;第27届中国高速公路信息化大会暨技术产品博览会在青岛市红岛国际会议展览中心盛大开幕。作为高速公路信息化领域的创新先锋&#xff0c;中威电子&…

计算机期刊征稿 | 计算机-网络系统:物联网系统架构、物联网使能技术、物联网通信和网络协议、物联网服务和应用以及物联网的社会影响

IEEE Internet of Things Journal 学科领域&#xff1a; 计算机-网络系统 期刊类型&#xff1a; SCI/SSCI/AHCI 收录数据库&#xff1a; SCI(SCIE),EI ISSN&#xff1a; 2327-4662 中科院&#xff1a; 1区 影响因子&#xff1a; 8.2 JCR&#xff1a; Q1 IEEE Internet…

springBoot统一响应类型3.3版本

前言&#xff1a; 通过实践而发现真理&#xff0c;又通过实践而证实真理和发展真理。从感性认识而能动地发展到理性认识&#xff0c;又从理性认识而能动地指导革命实践&#xff0c;改造主观世界和客观世界。实践、认识、再实践、再认识&#xff0c;这种形式&#xff0c;循环往…

mapbox基础,加载popup弹出窗

👨‍⚕️ 主页: gis分享者 👨‍⚕️ 感谢各位大佬 点赞👍 收藏⭐ 留言📝 加关注✅! 👨‍⚕️ 收录于专栏:mapbox 从入门到精通 文章目录 一、🍀前言1.1 ☘️mapboxgl.Map 地图对象1.2 ☘️mapboxgl.Map style属性1.3 ☘️popup 弹出窗 api1.3.1 ☘️构造函数1.…

MySQL基础语法1

目录 #1.创建和删除数据库 ​编辑#2.如果有lyt就删除,没有则创建一个新的lyt #3.切换到lyt数据库下 #4.创建数据表并设置列及其属性,name是关键词要用name包围 ​编辑 #5.删除数据表 #5.查看创建的student表 #6.向student表中添加数据,数据要与列名一一对应 #7.查询st…

【ESP32S3】esp32获取串口数据并通过http上传到前端

通过前面的学习&#xff08;前面没发过&#xff0c;因为其实就是跑它的demo&#xff09;了解到串口配置以及开启线程实现功能的工作流程&#xff0c;与此同时还有esp32作为STA节点&#xff0c;将数据通过http发送到服务器。 将这两者联合 其实是可以得到一个&#xff1a;esp32获…

CSS 美化页面(二)

一、CSS 属性详解 1、字体属性 (Font) 属性描述值示例简写属性font-family设置字体系列"Arial", sans-serif font: italic small-caps bold 16px/1.5 "Arial", sans-serif; font-size设置字体大小16px, 1.2em, 1remfont-weight设置字体粗细normal, bold,…

win32汇编环境,网络编程入门之十四

;win32汇编环境,网络编程入门之十四 ;在这一教程里&#xff0c;学习一下&#xff0c;如何得到网页的标题 ;这里需要理解一下html语言&#xff0c;<title> </title>标签对里面的内容即为网页的标题 ;其原理是把返回的字符串&#xff0c;按字节进行检查&#xff0c;发…

[已解决]服务器CPU突然飙高98%----Java程序OOM问题 (2024.9.5)

目录 问题描述问题排查问题解决参考资料 问题描述 业主单位服务器自8月29日晚上21:00起CPU突然飙高至98%&#xff0c;内存爆满&#xff0c;一直到9月5日&#xff1a; 问题排查 ①执行 top 命令查看Java进程PID top②执行top -Hp PID 命令查看具体的线程情况 top -Hp 3058输入上…

UI产品经理基础(六):如何解决用户的质疑?

在需求调查中遇到用户质疑“不专业”或“不了解需求”&#xff0c;本质上是用户对产品经理的信任缺失或沟通鸿沟导致的。要化解这种质疑&#xff0c;需从专业能力展示、沟通方式优化、用户参与感提升三个维度切入&#xff0c;结合具体场景采取针对性策略。以下是系统化的解决方…

小型水库大坝安全及水雨情监测技术方案

一、小型水库监测系统构成 小型水库雨水情测报和大坝安全监测系统由水库监测站点、通信网络和监测平台等组成&#xff0c;系统总体架构如图所示。 水库监测站点设施包括&#xff1a;雨量计、水位计、视频监视设备、渗压计、量水堰计、变形监测仪器、数据采集仪、遥测终端、水准…

win11+ubuntu双系统安装

操作步骤&#xff1a; 官网下载ubuntu 最新镜像文件 准备U盘 准备一个容量不小于 8GB 的 U 盘&#xff0c;用于制作系统安装盘。制作过程会格式化 U 盘&#xff0c;请注意提前备份数据。 制作U盘启动盘 使用rufus工具&#xff0c;或者 balenaEtcher工具&#xff08;官网安…

搭建前端环境和后端环境

搭建前端环境 ①、安装vscode&#xff0c;并安装相应的插件工具 ②、安装node.js&#xff0c;可以选择当前版本&#xff0c;或者其他版本 ③、创建工作区 创建一个空文件夹&#xff0c;然后通过vscode工具打开&#xff0c;保存为后缀名为.code-workspace ④、从gitee…