Redis 发布订阅模式深度解析:原理、应用与实践
在现代分布式系统架构中,实时消息传递机制扮演着至关重要的角色。Redis 作为一款高性能的内存数据库,其内置的发布订阅(Pub/Sub)功能提供了一种轻量级、高效的消息通信方案。本文将全面剖析 Redis 发布订阅模式,从其基本概念、工作原理到实际应用场景,再到性能优化和替代方案比较,帮助开发者深入理解并正确运用这一强大的消息通信机制。
一、Redis 发布订阅模式概述
1.1 什么是发布订阅模式
发布订阅模式是一种消息通信范式,它将消息的发送者(发布者)与接收者(订阅者)解耦。在这种模式中:
-
发布者不直接将消息发送给特定的接收者
-
消息被分类到不同的频道(Channel)
-
订阅者可以订阅一个或多个感兴趣的频道
-
当发布者向某个频道发布消息时,所有订阅该频道的订阅者都会收到消息
1.2 Redis Pub/Sub 的特点
Redis 实现的发布订阅系统具有以下显著特征:
-
实时性:消息几乎可以立即传递给所有订阅者
-
无状态性:Redis 不持久化任何订阅关系或消息
-
广播性质:一个消息可以同时被多个订阅者接收
-
轻量级:实现简单,性能开销小
-
支持模式匹配:可以使用通配符订阅多个频道
1.3 与其他消息系统的比较
特性 | Redis Pub/Sub | RabbitMQ | Kafka |
---|---|---|---|
持久化 | 不支持 | 支持 | 支持 |
消息回溯 | 不支持 | 支持 | 支持 |
性能 | 极高 | 高 | 高 |
复杂度 | 简单 | 中等 | 复杂 |
适用场景 | 实时通知 | 企业级消息队列 | 大数据流处理 |
二、Redis 发布订阅核心机制
2.1 底层数据结构实现
Redis 使用两种主要数据结构实现发布订阅功能:
-
频道订阅字典:一个保存了频道与订阅者客户端列表之间映射关系的字典
-
键:频道名称
-
值:订阅该频道的客户端链表
-
-
模式订阅列表:保存了所有模式订阅及其对应的客户端
这种数据结构设计使得:
-
发布消息时可以在 O(1) 时间内找到所有订阅者
-
订阅和取消订阅操作也非常高效
2.2 消息传递流程
-
客户端通过
SUBSCRIBE
命令订阅一个或多个频道 -
Redis 服务器将这些订阅信息记录在内存中
-
当有客户端执行
PUBLISH
命令时:
a. 查找频道订阅字典,获取所有订阅者
b. 检查模式订阅列表,匹配符合模式的订阅者
c. 将消息发送给所有匹配的订阅者 -
订阅者客户端接收到消息并处理
2.3 关键命令详解
2.3.1 基础订阅命令
SUBSCRIBE channel1 [channel2 ...]
-
订阅一个或多个频道
-
客户端进入订阅状态,只能使用订阅相关命令
-
返回确认信息,包含已订阅的频道和数量
2.3.2 模式订阅命令
PSUBSCRIBE pattern1 [pattern2 ...]
-
使用通配符模式订阅多个频道
-
支持的匹配模式:
-
h?llo
匹配 hello, hallo, hxllo 等 -
h*llo
匹配 hllo, heeeello 等 -
h[ae]llo
匹配 hello 和 hallo
-
2.3.3 发布命令
PUBLISH channel message
-
向指定频道发布消息
-
返回接收到消息的订阅者数量
-
消息可以是任意字符串,通常使用 JSON 等格式
2.3.4 取消订阅命令
UNSUBSCRIBE [channel ...]
PUNSUBSCRIBE [pattern ...]
-
取消订阅指定的频道或模式
-
不指定参数则取消所有订阅
三、Redis 发布订阅的高级特性
3.1 消息格式与协议
Redis Pub/Sub 使用简单的文本协议,消息格式如下:
-
订阅成功响应:
["subscribe", "channel_name", current_subscribe_count]
-
消息接收格式:
["message", "channel_name", "actual_message_content"]
-
模式匹配消息:
["pmessage", "original_pattern", "actual_channel", "message"]
3.2 客户端连接管理
-
订阅状态是连接级别的,每个连接维护自己的订阅列表
-
客户端断开后自动取消所有订阅
-
重新连接后需要重新订阅
3.3 性能特点
-
时间复杂度:
-
订阅/取消订阅:O(1)
-
发布消息:O(N+M),N是频道订阅者数量,M是匹配的模式订阅数量
-
-
内存消耗:
-
每个订阅大约消耗 64 字节
-
大量订阅会显著增加内存使用
-
-
网络影响:
-
每个消息都会产生独立的网络包
-
大量小消息可能导致网络拥堵
-
四、实战应用与代码示例
4.1 简单聊天室实现
# 发布者代码
import redisr = redis.Redis()
while True:message = input("Enter message: ")r.publish('chatroom', message)
# 订阅者代码
import redisdef handle_message(message):print(f"Received: {message['data'].decode()}")r = redis.Redis()
pubsub = r.pubsub()
pubsub.subscribe(**{'chatroom': handle_message})
thread = pubsub.run_in_thread()
4.2 实时通知系统
// Node.js 实现
const redis = require('redis');// 订阅者
const subscriber = redis.createClient();
subscriber.on('message', (channel, message) => {console.log(`Notification from ${channel}: ${message}`);
});
subscriber.subscribe('notifications');// 发布者
const publisher = redis.createClient();
setInterval(() => {publisher.publish('notifications', JSON.stringify({type: 'alert', content: 'Server update scheduled'}));
}, 5000);
4.3 跨服务事件总线
// Java 实现
public class EventBus {private final JedisPool jedisPool;public EventBus(JedisPool pool) {this.jedisPool = pool;}public void publish(String channel, String event) {try (Jedis jedis = jedisPool.getResource()) {jedis.publish(channel, event);}}public void subscribe(String channel, Consumer<String> handler) {new Thread(() -> {try (Jedis jedis = jedisPool.getResource()) {jedis.subscribe(new JedisPubSub() {@Overridepublic void onMessage(String channel, String message) {handler.accept(message);}}, channel);}}).start();}
}
五、最佳实践与性能优化
5.1 设计建议
-
频道命名规范:
-
使用有意义的层次结构,如
domain:entity:event
-
示例:
user:123:profile_update
-
-
消息格式:
-
使用 JSON 等标准格式
-
包含元数据:时间戳、事件类型等
-
-
错误处理:
-
实现重连机制
-
记录订阅状态
-
5.2 性能优化技巧
-
减少频道数量:
-
避免创建大量短期频道
-
合并相关事件到同一频道
-
-
消息精简:
-
压缩大消息
-
避免高频小消息
-
-
连接管理:
-
复用 Redis 连接
-
实现连接池
-
5.3 监控与维护
-
关键指标:
-
pubsub_channels
:当前活跃频道数量 -
pubsub_patterns
:模式订阅数量 -
网络流量监控
-
-
危险信号:
-
频道数量持续增长
-
订阅者响应缓慢
-
内存使用异常增加
-
六、局限性及替代方案
6.1 Redis Pub/Sub 的局限性
-
无持久化:
-
消息不保存,订阅者离线期间的消息会丢失
-
-
无确认机制:
-
无法确保消息被成功处理
-
-
扩展性限制:
-
大量订阅者时性能下降
-
集群环境下功能受限
-
6.2 Redis Stream 作为替代
Redis 5.0 引入的 Stream 数据结构解决了 Pub/Sub 的主要限制:
-
消息持久化
-
消费者组支持
-
消息回溯能力
-
更可靠的消息传递
# Stream 基本使用示例
XADD mystream * field1 value1 field2 value2
XREAD COUNT 2 STREAMS mystream 0
6.3 如何选择
-
选择 Pub/Sub 当:
-
需要极低延迟
-
允许偶尔消息丢失
-
简单广播场景
-
-
选择 Stream 当:
-
需要消息持久化
-
需要消费者组
-
重要业务消息
-
总结与展望
Redis 发布订阅模式提供了一种极其高效的实时消息通信机制,特别适合需要低延迟、高吞吐的实时通知场景。尽管它在可靠性方面存在局限,但在正确的使用场景下,它仍然是无可替代的轻量级解决方案。
随着 Redis 功能的不断演进,Stream 数据结构为需要更高可靠性的场景提供了选择。开发者应根据具体业务需求,在 Pub/Sub 的简单高效与 Stream 的可靠持久化之间做出权衡。
未来,Redis 可能会进一步增强其消息传递能力,可能的方向包括:
-
混合 Pub/Sub 和 Stream 的特性
-
改进的集群支持
-
更丰富的消息模式
无论如何,理解 Redis 发布订阅的核心原理和适用场景,将帮助开发者构建更加高效、可靠的实时应用系统。
相关文章:
Redis 发布订阅模式深度解析:原理、应用与实践
在现代分布式系统架构中,实时消息传递机制扮演着至关重要的角色。Redis 作为一款高性能的内存数据库,其内置的发布订阅(Pub/Sub)功能提供了一种轻量级、高效的消息通信方案。本文将全面剖析 Redis 发布订阅模式,从其基本概念、工作原理到实际…...
通义千问-langchain使用构建(三)
目录 序言docker 部署xinference1WSL环境docker安装2拉取镜像运行容器3使用的界面 本地跑chatchat1rag踩坑2使用的界面2.1配置个前置条件然后对话2.2rag对话 结论 序言 在前两天的基础上,将xinference调整为wsl环境,docker部署。 然后langchain chatcha…...
c++ 仿函数
示例代码: void testFunctor() {using Sum struct MyStruct {int operator() (int a, int b) const { // 重载()运算符return a b;}};Sum sum;std::cout << sum(9528, -1) << std::endl; } 打印: 仿函数意思是&am…...
hyper-v 虚拟机怎么克隆一台一样的虚拟机?
环境: hyper-v Win10专业版 问题描述: hyper-v 虚拟机怎么克隆一台一样的虚拟机? 解决方案: 以下是在 Hyper-V 中克隆虚拟机的几种方法: 方法一:使用导出和导入功能 导出虚拟机: 打开 H…...
操作系统:os概述
操作系统:OS概述 程序、进程与线程无极二级目录三级目录 程序、进程与线程 指令执行需要那些条件?CPU内存 需要数据和 无极 二级目录 三级目录...
【技巧】GoogleChrome浏览器开发者模式查看dify接口
回到目录 GoogleChrome浏览器开发者模式查看dify接口 1.搭建本地dify开发环境 参考 《 win10的wsl环境下调试dify的api后端服务(20250511发布)》 2.打开dify首页,进入开发者模式,Network页 勾选 Preserve log [图1] 3.填好用户名和密码,…...
Ocean: Object-aware Anchor-free Tracking
领域:Object tracking It aims to infer the location of an arbitrary target in a video sequence, given only its location in the first frame 问题/现象: Anchor-based Siamese trackers have achieved remarkable advancements in accuracy, yet…...
java中的循环结构
文章目录 流程控制顺序结构if单选择结构if双选择结构if多选择结构嵌套的if结构switch多选择结构 循环结构while循环do...while循环 for循环增强for循环 break continue练习案例 流程控制 顺序结构 java的基本结果就是顺序结构,除非特别指明,否则就按照…...
数学复习笔记 16
前言 例题真是经典。 background music 《青春不一样》 2.28 算一个行列式,算出来行列式不等于零,这表示矩阵式可逆的。但是这个算的秩是复合的,感觉没啥好办法了,我直接硬算了,之后再看解析积累好的方法。算矩阵…...
PySide6 GUI 学习笔记——常用类及控件使用方法(常用类颜色QColor)
文章目录 一、概述二、核心功能三、常用函数及方法四、代码示例五、注意事项 一、概述 QColor 是用于处理颜色的类,支持 RGB、HSV、HSL、CMYK 等多种颜色模型,提供颜色创建、转换、分量操作及格式转换功能。支持透明度设置,可通过颜色名称或…...
【Closure-Hayd】
RNA序列本身存在结构上的物理信息,因此可以利用文献提供的相关方法来对RNA序列的物理特征进行更加细致的提取。 几何向量编码(GVP模块)借鉴Rhodesign模型中的GVP(Geometric Vector Perceptron)模块,将每个…...
MySQL高可用架构
一、读写分离在高可用架构中的核心作用 1.读写分离与高可用的协同价值 在MySQL高可用架构中,读写分离不仅是性能优化的手段,更是提升系统容错能力的关键策略。通过将写操作(INSERT、UPDATE、DELETE) 集中到主节点,读…...
粒子群算法(PSO算法)
粒子群算法概述 1.粒子群优化算法(Particle Swarm Optimization,简称PSO)。粒子群优化算法是在1995年由Kennedy博士和Eberhart博士一起提出的,它源于对鸟群捕食行为的研究。 2.基本核心是利用群体中的个体对信息的共享从而使得整…...
信道编码技术介绍
信息与通信系统中的编码有4 种形式:信源编码、信道编码、密码编码和多址编码。 其中信道编码的作用是对信源经过压缩后的数据加一定数量受到控制的冗余,使得数据在传输中或接收中发生的差错可以被纠正或被发现,从而可以正确恢复出原始数据信息…...
JavaScript【4】数组和其他内置对象(API)
1.数组: 1.概述: js中数组可理解为一个存储数据的容器,但与java中的数组不太一样;js中的数组更像java中的集合,因为此集合在创建的时候,不需要定义数组长度,它可以实现动态扩容;js中的数组存储元素时,可以存储任意类型的元素,而java中的数组一旦创建后,就只能存储定义类型的元…...
【背包dp-----分组背包】------(标准的分组背包【可以不装满的 最大价值】)
通天之分组背包 题目链接 题目描述 自 01 01 01 背包问世之后,小 A 对此深感兴趣。一天,小 A 去远游,却发现他的背包不同于 01 01 01 背包,他的物品大致可分为 k k k 组,每组中的物品相互冲突,现在&a…...
docker-compose——安装mongo
编写docker-compose.yml version : 3.8services:zaomeng-mongodb:container_name: zaomeng-mongodbimage: mongo:latestrestart: alwaysports:- 27017:27017environment:- MONGO_INITDB_ROOT_USERNAMEroot- MONGO_INITDB_ROOT_PASSWORDpssw0rdvolumes:- ./mongodb/data:/data/…...
day 28
类 一个常见的类的定义包括了: 1. 关键字class 2. 类名 3. 语法固定符号冒号(:) 4. 一个初始化函数__init__(self) Pass占位符和缩进 Python 通过缩进来定义代码块的结构。当解释器遇到像 def, class, if, for 这样的语句,并且后面跟着冒号 : 时&…...
JavaScript入门【1】概述
1.JavaScript是什么? <font style"color:rgb(38,38,38);">Javascript (简称“JS”)是⼀种直译式脚本语⾔,⼀段脚本其实就是⼀系列指令,计算机通过这些指令来达成⽬标。它⼜是⼀种动态类型的编程语⾔。JS⽤来在⽹…...
MySQL 中 JOIN 和子查询的区别与使用场景
目录 一、JOIN:表连接1.1 INNER JOIN:内连接1.2 LEFT JOIN:左连接1.3 RIGHT JOIN:右连接1.4 FULL JOIN:全连接二、子查询:嵌套查询2.1 WHERE 子句中的子查询2.2 FROM 子句中的子查询2.3 SELECT 子句中的子查询三、JOIN 和子查询的区别3.1 功能差异3.2 性能差异3.3 使用场…...
DeepSeek 大模型部署全指南:常见问题、优化策略与实战解决方案
DeepSeek 作为当前最热门的开源大模型之一,其强大的语义理解和生成能力吸引了大量开发者和企业关注。然而在实际部署过程中,无论是本地运行还是云端服务,用户往往会遇到各种技术挑战。本文将全面剖析 DeepSeek 部署中的常见问题,提…...
Python 3.11详细安装步骤(包含安装包)Python 3.11详细图文安装教程
文章目录 前言Python 3.11介绍Python 3.11安装包下载Python 3.11安装步骤 前言 作为当前最热门的编程语言之一,Python 3.11 不仅拥有简洁优雅的语法,还在性能上实现了飞跃,代码运行速度提升显著。无论是初入编程的小白,还是经验丰…...
虚拟主播肖像权保护,数字时代的法律博弈
首席数据官高鹏律师团队 在虚拟主播行业蓬勃发展的表象之下,潜藏着一场关乎法律边界的隐形战争。当一位虚拟偶像的3D模型被非法拆解、面部数据被批量复制,运营方惊讶地发现——传统的肖像权保护体系,竟难以完全覆盖这具由代码与数据构成的“…...
硬件工程师笔记——二极管Multisim电路仿真实验汇总
目录 1 二极管基础知识 1.1 工作原理 1.2 二极管的结构 1.3 PN结的形成 1.4 二极管的工作原理详解 正向偏置 反向偏置 multisim使用说明链接 2 二极管特性实验 2.1 二极管加正向电压 2.2 二极管加反向电压 2.3 二极管两端的电阻 2.4 交流电下二级管工作 2.5 二极…...
学习笔记(C++篇)—— Day 6
1.内部类 如果一个类定义在另一个类的内部,就叫做内部类。 例如下面一个代码示例: class A { private:static int _k;int _h 1; public:class B // B默认就是A的友元{public:void foo(const A& a){cout << _k << endl; //OKcout <&…...
常见的实时通信技术(轮询、sse、websocket、webhooks)
1. HTTP轮询:最老实的办法 刚开始做实时功能时,我第一个想到的就是轮询。特别简单直白,就像你每隔5分钟就刷新一次朋友圈看看有没有新消息一样。 短轮询:勤快但费劲 短轮询就是客户端隔三差五地问服务器:"有新…...
2025年第三届盘古石杯初赛(智能冰箱,监控部分)
前言 所以去哪里可以取到自己家里的智能家居数据呢???? IOT物联网取证 1、分析冰箱,请问智能冰箱的品牌? [答案格式:xiaomi] Panasonic2、请问智能冰箱的型号? [答案格式&#x…...
[强化学习的数学原理—赵世钰老师]学习笔记02-贝尔曼方程
本人为强化学习小白,为了在后续科研的过程中能够较好的结合强化学习来做相关研究,特意买了西湖大学赵世钰老师撰写的《强化学习数学原理》中文版这本书,并结合赵老师的讲解视频来学习和更深刻的理解强化学习相关概念,知识和算法技…...
基于STM32的INA226电压电流检测仪
系统总体框图 功率检测装置原理图功能及模块连接说明 一、系统功能概述 该装置以STM32F103C8T6微控制器为核心,集成功率检测、数据交互、状态显示和用户提示功能,通过模块化设计实现稳定运行。 二、各模块功能及连接方式 按键模块 功能:…...
Android7 Input(七)App与input系统服务建立连接
概述 本文主要讲述Android 系统创建窗口时与输入管理系统服务通过InputChannel通道建立通信桥梁的过程。 本文涉及的源码路径 frameworks/native/libs/input/InputTransport.cpp frameworks/base/core/java/android/view/InputChannel.java frameworks/base/core/java/andr…...
1.2 C++第一个程序
第一个程序:Hello World 教程 目标 用 cout 输出文字,学会用 endl 换行。理解程序的基本结构,明白 main 函数的作用。 一、程序是什么?——像“魔法食谱” 比喻:写程序就像写一份做蛋糕的食谱! 食材&am…...
Hi3516DV500刷写固件
hi3516DV500刷固件 1、硬件连接 2、软件准备 3、刷固件步骤 一、硬件连接 特别注意的是,串口的接线顺序 通过网线连接好笔记本和开发板后,需要确认一下网口水晶头是否闪烁,以确认网络物理是否连通 二、软件资源准备 固件包准备 打开工具…...
完整卸载 Fabric Manager 的方法
目录 ✅ 完整卸载 Fabric Manager 的方法 1️⃣ 停止并禁用服务 2️⃣ 卸载 Fabric Manager 软件包 3️⃣ 自动清理无用依赖(可选) 4️⃣ 检查是否卸载成功 ✅ 补充(仅清除服务,不删包) ✅ 完整卸载 Fabric Mana…...
linux标准库头文件解析
linuxc标准库 C 标准库(C Standard Library)包含了一组头文件,这些头文件提供了许多函数和宏,用于处理输入输出、字符串操作、数学计算、内存管理等常见编程任务。。 头文件功能简介<stdio.h>标准输入输出库,包含…...
PLC和变频器之间如何接线
这篇文章想梳理一下,不同电平输出的PLC应该如何去接不同品牌的变频器 对于PLC的IO来讲,有高低电平输入的不同,有高低电平输出的区别 对于变频器的DI或DO来讲,不同的品牌内部线路和原理也有区别 我们场地现在用的是西门子1200的…...
【Spring】Spring的请求处理
欢迎来到啾啾的博客🐱。 记录学习点滴。分享工作思考和实用技巧,偶尔也分享一些杂谈💬。 欢迎评论交流,感谢您的阅读😄。 目录 引言HTTP/HTTPS协议Spring Web与Spring Web MVCSpring WebFlux 自定义的TPC/IP协议FTP、S…...
现代健康生活养生指南
现代社会中,熬夜加班、久坐不动、饮食不规律成为许多人的生活常态,由此引发的健康问题也日益增多。想要摆脱亚健康,不必依赖中医理念,从以下这些现代科学养生方法入手,就能逐步改善身体状况。 饮食上,注…...
使用tensorRT10部署低光照补偿模型
1.低光照补偿模型的简单介绍 作者介绍一种Zero-Reference Deep Curve Estimation (Zero-DCE)的方法用于在没有参考图像的情况下增强低光照图像的效果。 具体来说,它将低光照图像增强问题转化为通过深度网络进行图像特定曲线估计的任务。训练了一个轻量级的深度网络…...
题单:表达式求值1
题目描述 给定一个只包含 “加法” 和 “乘法” 的算术表达式,请你编程计算表达式的值。 输入格式 输入仅有一行,为需要计算的表达式,表达式中只包含数字、加法运算符 和乘法运算符 *,且没有括号。 所有参与运算的数字不超过…...
【ant design】ant-design-vue 4.0实现主题色切换
官网:Ant Design Vue — An enterprise-class UI components based on Ant Design and Vue.js 我图方便,直接在 app.vue 中加入的 <div class"app-content" v-bind:class"appOption.appContentClass"><a-config-provider…...
MinIO深度解析:从入门到实战——对象存储系统全指南
在当今数字化时代,数据存储至关重要。MinIO作为一款高性能的对象存储系统,正逐渐受到广泛关注。它与云原生存储系统相媲美,并且其API与Amazon S3完全兼容。本文将带您快速了解MinIO,并探讨其在实际中的应用场景。 一、关于MinIO …...
(8)python开发经验
文章目录 1 下载python2 pip安装依赖无法访问3 系统支持4 下载python文档5 设置虚拟环境6 编译安装python 更多精彩内容👉内容导航 👈👉Qt开发 👈👉python开发 👈 1 下载python 下载地址尽量不要下载最新版…...
uniapp自动构建pages.json的vite插件
对于 uniapp 来说,配置 pages.json 无疑是最繁琐的事情,具有以下缺点: 冗长,页面很多时 pages 内容会很长难找,有时候因为内容很长,导致页面配置比较难找,而且看起来比较凌乱json弊端ÿ…...
【MySQL进阶】如何在ubuntu下安装MySQL数据库
前言 🌟🌟本期讲解关于如何在ubuntu环境下安装mysql的详细介绍~~~ 🌈感兴趣的小伙伴看一看小编主页:GGBondlctrl-CSDN博客 🔥 你的点赞就是小编不断更新的最大动力 dz…...
解放双手的全自动抠图工具
软件介绍 本文要介绍的这款软件是Teorex PhotoScissors,是一款全自动抠图软件。 第二段:软件便捷性 这款来自国外的软件堪称神器,目前已解锁可无限使用。使用起来特别方便,无需安装,打开即可直接操作,并…...
Python多进程编程执行任务
我的需求如下:现有一批任务,使用进程池执行,每个任务执行耗时不一样,任务并发执行期间,需要每隔一段时间监控任务执行进度 直接贴代码: import multiprocessing import time import random from multiproc…...
【Linux笔记】——Linux线程封装
🔥个人主页🔥:孤寂大仙V 🌈收录专栏🌈:Linux 🌹往期回顾🌹:【Linux笔记】——Linux线程控制创建、终止与等待|动态库与内核联动 🔖流水不争,争的是…...
ChatGPT + DeepSeek 联合润色的 Prompt 模板指令合集,用来润色SCI论文太香了!
对于非英语母语的作者来说,写SCI论文的时候经常会碰到语法错误、表达不够专业、结构不清晰以及术语使用不准确等问题。传统的润色方式要么成本高、效率低,修改过程又耗时又费力。虽然AI工具可以帮助我们来润色论文,但单独用ChatGPT或DeepSeek都会存在内容泛泛、专业性不足的…...
【typenum】 9 与常量泛型桥接(generic_const_mappings.rs)
一、源码 该代码提供了常量结构体与库类型的转换。 // THIS IS GENERATED CODE //! Module with some const-generics-friendly definitions, to help bridge the gap //! between those and typenum types. //! //! - It requires the const-generics crate feature to be…...
并发学习之synchronized,JVM内存图,线程基础知识
文章目录 Java内存图内存图区域介绍执行流程 进程和线程概念解释线程的6种状态简述等待队列和同步队列(阻塞队列)线程之间是独立的 synchronized静态方法非静态方法代码块 知识总结: 方法区存储类信息正在执行的程序叫进程,进程会…...