spring-webflux的一些概念的理解
Spring5的webflux可以支持高吞吐量,使用相同的资源可以处理更加多的请求,它将会成为未来技术的趋势,但是相对于学习其他的框架相比,它的学习曲线很高,综合了很多现有的技术,即使按照教程学习能编写代码,但是仍然会感觉不够理解,要想真正的理解webflux,我觉得需要掌握以下几点:
1.学习jdk8的lambda表达式和stream流编程思想,
2.理解响应式编程概念,理解背压和实现机制。
理解了以上两点,很容易理解webflux的基石reactor,再学习webflux就很简单了!
学习lambda表达式
Lambda 表达式是一个匿名函数,源于数学λ演算。是闭包函数,但闭包并不一定是Lambda 函数。
它可以赋值给变量,作为函数参数,作为函数返回值。
Lambda的本质在编译的时候在类中动态生成method方法,方法可以是static的也可以是非static的,主要取决于表达式内是否包含this这个变量,如果包含就生成动态的method方法,如果不包含就生成静态的method方法。
Lambda表达式的优点,大大的降低了编写代码的量,并大大提高了代码的可维护和可阅读性。
Lambda的惰性求值,只有在实际调用过程中才触发,像日志输出:
// 打印日志前需要先判断日志级别if(logger.isLoggable(Level.DEBUG)){logger.debug("====用户:"+username);}
如果没有if条件判断,即使level不是debug,也会把执行“====用户:”+username的操作,浪费了性能,如果加上if条件判断代码量又很大,不利于代码的维护。如果用Lambda表达式是如何呢?
// 使用lambda表达式的惰性求值,不需要判断日志级别logger.debug(()->"====用户:"+username);
因为Lambda的特点,实际上字符串相加的操作并不会执行,同时代码也少了,也容易维护了。
Stream流的概念
Stream 不是集合元素,它不是数据结构并不保存数据,它是有关算法和计算的,它更像一个高级版本的 Iterator。原始版本的 Iterator,用户只能显式地一个一个遍历元素并对其执行某些操作;高级版本的 Stream,用户只要给出需要对其包含的元素执行什么操作,比如 “过滤掉长度大于 10 的字符串”、“获取每个字符串的首字母”等,Stream 会隐式地在内部进行遍历,做出相应的数据转换。
Stream 就如同一个迭代器(Iterator),单向,不可往复,数据只能遍历一次,遍历过一次后即用尽了,就好比流水从面前流过,一去不复返。
而和迭代器又不同的是,Stream 可以并行化操作,迭代器只能命令式地、串行化操作。顾名思义,当使用串行方式去遍历时,每个 item 读完后再读下一个 item。而使用并行去遍历时,数据会被分成多个段,其中每一个都在不同的线程中处理,然后将结果一起输出。Stream 的并行操作依赖于 Java7 中引入的 Fork/Join 框架(JSR166y)来拆分任务和加速处理过程。
这个特点大大提高了硬件设备的利用率,提高了系统性能。
虽然大部分情况下stream是容器调用Collection.stream()方法得到的,但stream和collections有以下不同:
无存储。stream不是一种数据结构,它只是某种数据源的一个视图,数据源可以是一个数组,Java容器或I/O channel等。
为函数式编程而生。对stream的任何修改都不会修改背后的数据源,比如对stream执行过滤操作并不会删除被过滤的元素,而是会产生一个不包含被过滤元素的新stream。
惰式执行。stream上的操作并不会立即执行,只有等到用户真正需要结果的时候才会执行。
可消费性。stream只能被“消费”一次,一旦遍历过就会失效,就像容器的迭代器那样,想要再次遍历必须重新生成。
对stream的操作分为为两类,中间操作(intermediate operations)和结束操作(terminal operations),二者特点是:
中间操作总是会惰式执行,调用中间操作只会生成一个标记了该操作的新stream,仅此而已。
结束操作会触发实际计算,计算发生时会把所有中间操作积攒的操作以pipeline的方式执行,这样可以减少迭代次数。计算完成之后stream就会失效。
响应式编程的概念
响应式编程是一种关注于数据流data streams)和事件传递的异步编程方式。它是面向对象编程中的“观察者模式”的在多线程异步编程一种实现。
在响应式流中,当有新的数据到来的时候,由发布者(Publisher) 通知订阅者(Subscriber)。此外,对推送来的数据的操作 是通过一种声明式(declaratively)而不是命令式(imperatively)的方式表达的:开发者通过 描述“控制流程”来定义对数据流的处理逻辑。
除了数据推送以外,响应式编程对错误处理(error handling)和完成(completion)的定义实现也很完善。 一个 可以推送新的数据到它的 (调用 方法), 同样也可以推送错误(调用 方法)和完成(调用 方法)信号。 错误和完成信号都可以终止响应式流。
响应式编程的背压机制
背压是指在异步场景中,被观察者发送事件速度远快于观察者的处理速度的情况下,一种告诉上游的被观察者降低发送速度的策略。简而言之,背压是流速控制的一种策略。
理解了背压的概念,在整体设计的时候就要考虑流水线上的每一个操作的时候就知道该怎么设计,尽量每个环节的执行时间大约一致,保证整体的处理速度比较均衡。
reactor的概念
Project Reactor(以下简称“Reactor”)与Spring是兄弟项目,侧重于Server端的响应式编程,主要 artifact 是 reactor-core,这是一个基于 Java 8 的实现了响应式流规范 (Reactive Streams specification)的响应式库。
Reactor中的发布者(Publisher)由和两个类定义,它们都提供了丰富的操作符(operator)。一个Flux对象代表一个包含0..N个元素的响应式序列,而一个Mono对象代表一个包含零/一个(0..1)元素的结果。
既然是“数据流”的发布者,Flux和Mono都可以发出三种“数据信号”:元素值、错误信号、完成信号,错误信号和完成信号都是终止信号,完成信号用于告知下游订阅者该数据流正常结束,错误信号终止数据流的同时将错误传递给下游订阅者。
相关文章:
spring-webflux的一些概念的理解
Spring5的webflux可以支持高吞吐量,使用相同的资源可以处理更加多的请求,它将会成为未来技术的趋势,但是相对于学习其他的框架相比,它的学习曲线很高,综合了很多现有的技术,即使按照教程学习能编写代码&…...
OpenCV快速入门:特征点检测与匹配
文章目录 前言一、角点检测1.1 角点特征1.1.1 角点特征概念1.1.2 角点的特点1.1.3 关键点绘制代码实现1.1.4 函数解析 1.2 Harris角点检测1.2.1 Harris角点检测原理1.2.2 Harris角点检测公式1.2.3 代码实现1.2.4 函数解析 1.3 Shi-Tomasi角点检测1.3.1 Shi-Tomasi角点检测原理1…...
旋转的数组
分享今天看到的一个题目,不同思路解法 题目 思路1:时间复杂度0(N*k) void rotate(int *a,int N,int k)//N为数组元素个数 { while(k--) { int tema[N-1]; for(int rightN-2;right>0;right--) { a[right1]a[right]; } a[0]tem; …...
Hive VS Spark
spark是一个计算引擎,hive是一个存储框架。他们之间的关系就像发动机组与加油站之间的关系。 类似于spark的计算引擎还有很多,像mapreduce,flink等等。 类似于hive的存储框架也是数不胜数,比如pig。 最底层的存储往往都是使用h…...
SAST静态分析工具所支持的规则
综合国内外SAST工具支持的规则,这些规则包括了国际标准、国内标准、行业标准等,这里我罗列了一下,这些规则对应的标准集合。 评估一款SAST工具时,支持规则集的多少,且每个规则集是否为全集,或者接近全集&am…...
torch 的数据加载 Datasets DataLoaders
点赞收藏关注! 如需要转载,请注明出处! torch的模型加载有两种方式: Datasets & DataLoaders torch本身可以提供两数据加载函数: torch.utils.data.DataLoader()和torch.utils.data.Datase…...
【Promise】某个异步方法执行结束后 在执行下面方法
使用Promise ,当 layer.msg(查询成功) 这个方法执行结束后 ,下面代码才会执行 let thas this async function showMessage() {await new Promise(resolve > layer.msg(查询成功, resolve));// 这里的代码将在 layer.msg 执行结束后执行thas.isGuaran…...
任意文件下载漏洞(CVE-2021-44983)
简介 CVE-2021-44983是Taocms内容管理系统中的一个安全漏洞,可以追溯到版本3.0.1。该漏洞主要源于在登录后台后,文件管理栏存在任意文件下载漏洞。简言之,这个漏洞可能让攻击者通过特定的请求下载系统中的任意文件,包括但不限于敏…...
C++(20):通过source_location实现日志函数
C++20中引入了std::source_location,用来描述函数调用的上下文信息。 其主要的成员函数如下: line():获取行号。column():获取列号。file_name():获取文件名。function_name():获取函数域名。#include <iostream> #include <string_view> #include <sour…...
【数据结构】树与二叉树(廿二):树和森林的遍历——后根遍历(递归算法PostOrder、非递归算法NPO)
文章目录 5.1 树的基本概念5.1.1 树的定义5.1.2 森林的定义5.1.3 树的术语 5.2 二叉树5.3 树5.3.1 树的存储结构1. 理论基础2. 典型实例3. Father链接结构4. 儿子链表链接结构5. 左儿子右兄弟链接结构 5.3.2 获取结点的算法5.3.3 树和森林的遍历1. 先根遍历(递归、非…...
精通Nginx(17)-安全管控之防暴露、限制访问、防DDos攻击、防爬虫、防非法引用
安全是每个系统都需要考虑的关键因素,Nginx在这方面提供了丰富的功能,使我们可以就实际情形做很精细调整。这些功能包括防信息暴露、客户端访问限制、通讯加密、防DDos攻击、防爬虫、防非法引用及防非法域名请求等。 目录 防信息暴露 关闭版本号 关闭目录列表 客户端访问…...
STM32 Flash
FLASH简介 Flash是常用的用于存储数据的半导体器件,它具有容量大,可重复擦写,按“扇区/块”擦除、掉电后数据可继续保存的特性。 常见的FLASH主要有NOR FLASH和NAND FLASH两种类型。NOR和NAND是两种数字门电路,可以简单地认为FL…...
文件批量重命名技巧:图片文件名太长怎么办?告别手动改名方法
在日常生活中,常常会遇到文件名过长导致的问题。尤其是在处理大量图片文件时,过长的文件名可能会使得文件管理变得混乱不堪。现在来看下云炫文件管理器如何批量重命名,让图片文件名变得更简洁,提高工作效率。 操作1、在云炫文件…...
微信小程序手写滑动tab
微信小程序手写滑动tab index.wxml <view class"tab-bar"> <scroll-view scroll-x class"tab-scroll"> <block wx:for"{{tabs}}" wx:key"index"> <view class"tab-item {{currentIndex index ? acti…...
一文读懂如何安全地存储密码
目录 引言 明文存储 基本哈希存储 加盐哈希存储 适应性哈希算法 密码加密存储 小结 引言 密码是最常用的身份验证手段,既简单又高效。密码安全是网络安全的基石,对保护个人和组织信息的安全具有根本性的作用。然而有关密码泄漏的安全问题一再发生…...
【运维面试100问】(六)buffer和cache的区别
本站以分享各种运维经验和运维所需要的技能为主 《python零基础入门》:python零基础入门学习 《python运维脚本》: python运维脚本实践 《shell》:shell学习 《terraform》持续更新中:terraform_Aws学习零基础入门到最佳实战 《k8…...
创建域名邮箱邮件地址的方法与步骤
如何创建域名邮箱邮件地址?使用Zoho Mail创建域名邮箱邮件地址的步骤简单易懂,操作便捷。从其他邮箱迁移到Zoho Mail的过程也相当顺畅,您可以轻松为所有员工创建具有企业邮箱域名的电子邮件地址。 步骤1:添加并验证您的域名 首先,…...
Qt框架学习(1)
1.安装Qt官网 安装需注意的是,要安装开源版(有钱当我没说),而安装包都是一样的,主要是在注册账户时选择个人开发,而不要选公司,否则在安装时登录账号后会安装商业版Qt. 2.Qt中的快捷键 快捷键解释F4头文件和实现文件切换ShiftF…...
3D电路板在线渲染案例
从概念上讲,这是有道理的,因为PCB印制电路板上的走线从一个连接到下一个连接的路线基本上是平面的。 然而,我们生活在一个 3 维世界中,能够以这种方式可视化电路以及相应的组件,对于设计过程很有帮助。本文将介绍KiCad中基本的3D查看功能,以及如何使用NSDT 3DConvert在线…...
ResizeObserver loop limit exceeded报错解决方案
前言: 控制台没有报错,但是开发Vue项目过程中一直报ResizeObserver loop limit exceeded 错,找到以下解决方式。在main.js文件中重写 ResizeObserver 方法。 main.js文件 (完整版) import { createApp } from "v…...
real-anime-z部署教程:端口7860映射与Nginx反向代理配置,支持HTTPS安全访问
real-anime-z部署教程:端口7860映射与Nginx反向代理配置,支持HTTPS安全访问 1. 镜像介绍 real-anime-z 是一个专为二次元插画创作设计的文生图镜像,能够快速生成高质量的动漫风格图像。无论是角色设计、头像创作还是宣传插画,这…...
我的YOLO毕设踩坑实录:从CUDA报错到成功跑通GPU推理的全流程避坑指南
我的YOLO毕设踩坑实录:从CUDA报错到成功跑通GPU推理的全流程避坑指南 第一次接触YOLO目标检测框架时,我天真地以为只要按照教程安装几个库就能轻松跑通Demo。直到真正开始配置环境,才深刻体会到"深度学习从入门到放弃"的段子并非玩…...
15分钟搞定Ncorr 2D数字图像相关软件:材料力学位移测量的终极指南
15分钟搞定Ncorr 2D数字图像相关软件:材料力学位移测量的终极指南 【免费下载链接】ncorr_2D_matlab 2D Digital Image Correlation Matlab Software 项目地址: https://gitcode.com/gh_mirrors/nc/ncorr_2D_matlab 还在为复杂的数字图像相关软件安装而烦恼吗…...
终极指南:深入解析Godot PCK文件解包器的完整工作流程
终极指南:深入解析Godot PCK文件解包器的完整工作流程 【免费下载链接】godot-unpacker godot .pck unpacker 项目地址: https://gitcode.com/gh_mirrors/go/godot-unpacker godot-unpacker是一款专业的Godot游戏资源解包工具,专门用于提取Godot引…...
非常优秀的nds模拟器器melonds-V1.0RC
一款十分优秀的nds模拟器.支持压缩包和中文命名的rom.有独特的屏幕布局.兼容性强.占用资源少.硬件要求比较低.十分推荐.喜欢的可以去下载.(2楼放地址) windows最新的是Apr 9th 2025,网页下面有 之前的版本有汉化,其实这个没啥必要…...
告别Photoscan卡顿!手把手教你用Metashape 1.7.4从航片到DOM/DEM的完整流程(附性能优化技巧)
告别Photoscan卡顿!手把手教你用Metashape 1.7.4从航片到DOM/DEM的完整流程(附性能优化技巧) 航测数据处理工程师最头疼的莫过于软件卡顿和漫长的等待时间。当你在处理数百张航拍照片时,突然弹出的"无响应"提示或进度条…...
告别VisionMaster原生界面:用C#和VM SDK 4.2打造你的专属视觉检测上位机
从零构建工业级视觉检测上位机:C#与VisionMaster SDK深度整合实战 在工业自动化领域,视觉检测系统正逐渐成为质量管控的核心环节。然而,标准化的视觉软件往往难以满足企业对界面交互、数据整合和品牌一致性的高阶需求。本文将带你深入探索如何…...
如何解决Linux下CH341SER驱动问题:CH340/CH341 USB转串口完全指南
如何解决Linux下CH341SER驱动问题:CH340/CH341 USB转串口完全指南 【免费下载链接】CH341SER CH341SER driver with fixed bug 项目地址: https://gitcode.com/gh_mirrors/ch/CH341SER 在Linux系统中连接CH340/CH341系列USB转串口设备时,驱动问题…...
AVX-512内存对齐踩坑实录:从‘段错误’到完美运行的避坑指南
AVX-512内存对齐踩坑实录:从‘段错误’到完美运行的避坑指南 当你在深夜的办公室里,面对一个神秘的Segmentation fault错误,而代码逻辑明明毫无破绽时,那种挫败感足以让任何开发者抓狂。这正是我第一次尝试将AVX-512指令集集成到现…...
嵌入式C语言与轻量大模型适配终极 checklist:12项硬性约束、5类编译器特异性陷阱、1次烧录即生效方案
第一章:嵌入式C语言与轻量级大模型适配如何实现快速接入在资源受限的嵌入式设备(如 Cortex-M4/M7、RISC-V MCU)上运行大语言模型,关键在于将模型推理能力以最小开销融入 C 语言生态。这并非简单移植 Python 推理框架,而…...
