Java 内存模型(JMM)与内存屏障:原理、实践与性能权衡
Java 内存模型(JMM)与内存屏障:原理、实践与性能权衡
在多线程高并发时代,Java 内存模型(JMM) 及其背后的内存屏障机制,是保障并发程序正确性与性能的基石。本文将系统梳理 JMM 的核心原理、内存屏障的实现与分类、典型应用场景以及性能影响,帮助开发者深入理解底层机制,并指导实际并发程序设计。
一、JMM(Java Memory Model)核心定义与价值
1.1 定义
Java 内存模型(JMM)是 Java 并发编程的规范抽象。它通过定义主内存(共享内存)与工作内存(线程私有缓存)的交互规则,解决多线程环境下的数据可见性、有序性和原子性问题。
1.2 价值
- 硬件抽象
现代 CPU 的多级缓存(L1/L2/L3/主内存)和写缓冲区(Store Buffer)导致线程间变量可见性延迟。JMM 通过“主内存-工作内存”模型屏蔽底层差异,简化开发。 - 跨平台兼容
统一不同硬件(如 x86、ARM、PowerPC)的内存访问语义,确保 Java 程序在不同平台上表现一致。 - 约束指令重排序
明确编译器、CPU 可优化的边界,避免因重排序导致的并发逻辑错误。
二、内存屏障(Memory Barrier)原理与类型
2.1 硬件层原理
- 现代 CPU 采用缓存一致性协议(如 MESI)保证核心间缓存同步,但Store Buffer 和 Load Buffer 的异步设计会导致内存操作重排序(Memory Reordering)。
- 内存屏障(Memory Barrier)是 CPU 和编译器提供的特殊指令,用于约束这种重排序,保障多线程语义正确。
2.2 内存屏障类型
屏障类型 | 作用 | 典型 x86 指令 |
---|---|---|
LoadLoad | 禁止后续读操作重排到当前读之前 | LFENCE |
StoreStore | 禁止后续写操作重排到当前写之前 | SFENCE |
LoadStore | 禁止后续写操作重排到当前读之前 | 组合实现 |
StoreLoad | 禁止后续读操作重排到当前写之前,强制刷新缓存,最重 | MFENCE |
- StoreLoad 屏障最为严格,常用于 volatile 写、锁释放,确保写入对其他线程立即可见。
三、Happens-Before 原则与 JMM 语义
3.1 Happens-Before 核心规则
- 程序顺序规则:单线程内,前面的操作 happens-before 后面的操作。
- 锁规则:对同一把锁的 unlock happens-before 之后的 lock。
- volatile 规则:对 volatile 变量的写 happens-before 后续的读。
- 线程启动/终止规则:Thread.start() 之前的操作 happens-before 线程内代码;Thread.join() 之后的操作看到线程内的所有结果。
3.2 屏障与 Happens-Before 的协作
- Happens-Before 是逻辑层约束,内存屏障是物理实现手段。
- 例如,volatile 写插入 StoreStore + StoreLoad 屏障,synchronized 释放锁插入 StoreLoad 屏障,确保内存可见性和有序性。
四、内存屏障对性能的影响
4.1 不同屏障的性能开销
屏障类型 | 主要操作 | 性能影响 |
---|---|---|
StoreStore | 刷新写缓冲区 | 低(纳秒级) |
LoadLoad | 保证读顺序 | 低 |
StoreLoad | 刷新写缓冲区+同步缓存 | 高(需主存响应) |
- volatile 写操作(StoreLoad 屏障)比普通变量写慢 20-30 倍(纳秒级差异)。
- synchronized 退出(StoreLoad 屏障+上下文切换),耗时 10-30 微秒。
4.2 性能权衡
- 屏障越重,性能损耗越大,但并发安全性更高。
- 在高并发场景下,需要结合业务场景权衡正确性与性能,必要时借助 JMH 等工具量化测试。
五、典型应用场景与最佳实践
5.1 volatile 关键字
场景
- 状态标志、单次写入的共享配置等。
示例:双重检查锁定单例模式(DCL)
public class Singleton {private static volatile Singleton instance; // volatile 禁止重排序public static Singleton getInstance() {if (instance == null) {synchronized (Singleton.class) {if (instance == null) {instance = new Singleton(); // volatile 写屏障}}}return instance;}
}
说明:volatile 禁止 instance 对象创建过程中的指令重排,防止返回未初始化对象。
5.2 无锁编程范式
CAS(Compare-And-Swap)
- 基于硬件原子指令(如 x86 的 LOCK CMPXCHG),无需加锁即可实现线程安全。
class Counter {private volatile int value;private static final Unsafe UNSAFE = Unsafe.getUnsafe();private static final long VALUE_OFFSET;static {try {VALUE_OFFSET = UNSAFE.objectFieldOffset(Counter.class.getDeclaredField("value"));} catch (Exception e) { throw new Error(e); }}public void increment() {int oldVal;do {oldVal = UNSAFE.getIntVolatile(this, VALUE_OFFSET); // LoadLoad 屏障} while (!UNSAFE.compareAndSwapInt(this, VALUE_OFFSET, oldVal, oldVal + 1));}
}
说明:getIntVolatile 保证读取最新值,CAS 操作隐含 StoreLoad 屏障,确保写入立即对其他线程可见。
5.3 线程间状态同步
错误示例
class TaskRunner {private boolean shutdownRequested = false; // 未加 volatilepublic void shutdown() {synchronized (this) { shutdownRequested = true; }}public void executeTask() {if (shutdownRequested) { throw new IllegalStateException(); }// 执行任务...}
}
问题:未同步的读操作可能看到过期值,导致逻辑错误。
优化方案
- 将 shutdownRequested 声明为 volatile;
- 或在读取时加 synchronized。
六、指令重排序与内存屏障的关系
6.1 本质关系
指令重排类型 | 内存屏障介入方式 | 应用场景 |
---|---|---|
编译器优化重排序 | 编译器屏障(如 volatile) | volatile 变量声明 |
CPU 指令级重排序 | CPU 屏障指令(如 MFENCE) | CAS、锁释放 |
内存系统重排序 | 强制缓存刷新(StoreLoad 屏障) | 锁释放、volatile写 |
6.2 阻断机制
- 编译器层:volatile 变量声明插入编译器屏障,阻止重排序。
- CPU 层:硬件屏障(如 LOCK 前缀)强制顺序执行并刷新缓存。
七、JMM 与内存屏障协同实现并发安全
- JMM 通过 Happens-Before 规则定义逻辑约束;
- 内存屏障作为硬件实现手段,保障指令执行的可见性与有序性;
- volatile、synchronized、CAS 等应用层机制,基于底层屏障封装出易用接口,开发者可直接利用。
八、总结与实践建议
- 理解底层原理:深入把握 JMM 的主内存-工作内存模型与 Happens-Before 规则,理清并发可见性与有序性根源。
- 合理选择屏障类型:volatile 适用于轻量状态同步,锁机制用于复杂并发场景,无锁算法(CAS、LongAdder)适合高并发计数等热点操作。
- 关注性能权衡:过度使用重型屏障(如 StoreLoad)会影响吞吐量,需结合 JMH 等工具实测优化。
- 规范代码实践:所有多线程共享变量,必须用 volatile 或锁保护;避免低级同步错误。
参考代码汇总
1. 双重检查锁定单例
public class Singleton {private static volatile Singleton instance;public static Singleton getInstance() {if (instance == null) {synchronized (Singleton.class) {if (instance == null) {instance = new Singleton();}}}return instance;}
}
2. CAS 无锁计数器
class AtomicCounter {private volatile int value;public void increment() {int oldValue;do {oldValue = value; // volatile 读(LoadLoad 屏障)} while (!compareAndSwap(oldValue, oldValue + 1));}
}
3. 线程间状态同步
class TaskExecutor {private volatile boolean isShutdown = false;public void shutdown() { isShutdown = true; }public void executeTask() {if (!isShutdown) { /* 执行任务 */ }}
}
结语
JMM 与内存屏障是 Java 并发安全的底层保障。理解它们的原理和实现,有助于编写高效、可靠的多线程程序。开发者在实际工作中应善用 volatile、锁机制与无锁算法,结合性能测试工具,科学平衡正确性与高性能。
推荐阅读:
- Java 并发编程实战
- 深入理解 Java 虚拟机
- 官方 JDK 并发包文档
如有疑问,欢迎留言交流!
相关文章:
Java 内存模型(JMM)与内存屏障:原理、实践与性能权衡
Java 内存模型(JMM)与内存屏障:原理、实践与性能权衡 在多线程高并发时代,Java 内存模型(JMM) 及其背后的内存屏障机制,是保障并发程序正确性与性能的基石。本文将系统梳理 JMM 的核心原理、内…...
1.6 偏导数
(铺垫)全导数与偏导数看似相似,实则对应不同维度的变化观察。理解它们的差异需要从"变量自由度"切入: (核心差异解剖) 维度偏导数全导数变量关系其他变量被强制锁定所有变量都通过中间变量关联…...
网络爬虫学习之正则表达式
开篇 本文整理自《python3 网络爬虫开发实战》的学习笔记。 笔记整理 match match是一种常用的匹配方法,向它传入要匹配的字符串以及正则表达式,就可以检测这个正则表达式是否和字符串相匹配。 match会尝试从字符串的起始位置开始匹配正则表达式&#x…...
Pytorch常用统计和矩阵运算
文章目录 常用统计函数torch.prod()求积torch.sum()求和torch.mean()求均值torch.max()求最值torch.var() 方差torch.std()标准差 常见矩阵运算矩阵乘法点积 (torch.dot)批量矩阵乘法 (torch.bmm)奇异值分解 (SVD)特征分解 (torch.eig)矩阵求逆 (torch.inverse)伪逆 (torch.pin…...
PyTorch Lightning实战 - 训练 MNIST 数据集
MNIST with PyTorch Lightning 利用 PyTorch Lightning 训练 MNIST 数据。验证梯度范数、学习率、优化器对训练的影响。 pip show lightning Version: 2.5.1.post0Fast dev run DATASET_DIR"/repos/datasets" python mnist_pl.py --output_grad_norm --fast_dev_run…...
内存泄漏系列专题分析之十一:高通相机CamX ION/dmabuf内存管理机制Camx ImageBuffer原理
【关注我,后续持续新增专题博文,谢谢!!!】 上一篇我们讲了:内存泄漏系列专题分析之八:高通相机CamX内存泄漏&内存占用分析--通用ION(dmabuf)内存拆解 这一篇我们开始讲: 内存泄漏系列专题分析之十一:高通相机CamX ION/dmabuf内存管理机制Camx ImageBuf…...
MySQL-逻辑架构
MySQL服务器逻辑架构图 主要分层结构 1.连接层 功能:处理连接、安全认证、线程管理等 核心模块:连接器:支持不同语言(JDBC)与MySQL交互;线程连接池:管理线程连接,减少线程频繁创建…...
架构思维:通用架构模式_系统监控的设计
文章目录 引言什么是监控三大常见监控类型1. 次数监控2. 性能监控3. 可用率监控 落地监控1. 服务入口2. 服务内部3. 服务依赖 监控时间间隔的取舍小结 引言 架构思维:通用架构模式_从设计到代码构建稳如磐石的系统 架构思维:通用架构模式_稳如老狗的SDK…...
架构、构架、结构、框架之间有什么区别?|系统设计|系统建模
在技术与知识中,我们总是频繁地遇到一些高度抽象、看似类似、却又各自承载着不同思想重量的词汇。“架构”、“构架”、“结构”、“框架”即是其中最为常见又最为令人困惑的一组术语。它们既是工程师们日常工作的核心语言,也是学者们在探索系统、组织、…...
系统架构设计(五):构件
定义 构件(Component)是指一个具有明确边界和独立部署能力的模块化单元,能够封装实现细节,并通过接口与其他构件协作完成系统功能。 主要特性 特性说明可复用性构件可以在不同系统中被重复使用。可部署性构件可以独立部署&…...
【系统架构师】2025论文《基于架构的软件设计方法》【最新】
😊你好,我是小航,一个正在变秃、变强的文艺倾年。 🔔本文分享【系统架构师】2025论文《系统可靠性设计》,期待与你一同探索、学习、进步,一起卷起来叭! 目录 项目介绍背景介绍系统模块技术栈基于…...
MultiTTS 1.7.6 | 最强离线语音引擎,提供多音色无障碍朗读功能,附带语音包
MultiTTS是一款免费且支持离线使用的文本转语音(TTS)工具,旨在为用户提供丰富的语音包选项,实现多音色无障碍朗读功能。这款应用程序特别适合用于阅读软件中的离线听书体验,提供了多样化的语音选择,使得听书…...
Costmap代价地图
以下为ROS navigation导航工具包的move_base框架图。其中有两个关于代价地图的模块(红框所框),全局代价地图global_costmap和局部代价地图local_costmap,这两个代价地图实际上是调用的同一个功能包代码,通过配置不同的参数实例化为两个代价地…...
用生活例子通俗理解 Python OOP 四大特性
让我们用最生活化的方式,结合Python代码,来理解面向对象编程的四大特性。 1. 封装:像使用自动售货机 生活比喻: 你只需要投币、按按钮,就能拿到饮料 不需要知道机器内部如何计算找零、如何运送饮料 如果直接打开机…...
大规模容器集群怎么规划
规划大规模容器集群需要综合考虑多个方面,以下是一些关键的规划要点: 业务需求分析 应用类型和特点:明确容器集群上运行的应用类型,如 Web 应用、数据库、大数据处理等。不同类型的应用对资源的需求和性能要求各不相同。例如&am…...
机器学习第七讲:概率统计 → 预测可能性,下雨概率70%就是典型应用
机器学习第七讲:概率统计 → 预测可能性,下雨概率70%就是典型应用 资料取自《零基础学机器学习》。 查看总目录:学习大纲 关于DeepSeek本地部署指南可以看下我之前写的文章:DeepSeek R1本地与线上满血版部署:超详细手…...
蓝桥杯13届 卡牌
问题描述 这天, 小明在整理他的卡牌。 他一共有 n 种卡牌, 第 i 种卡牌上印有正整数数 i(i∈[1,n]), 且第 i 种卡牌 现有 ai 张。 而如果有 n 张卡牌, 其中每种卡牌各一张, 那么这 n 张卡牌可以被称为一 套牌。小明为了凑出尽可能多套牌, 拿出了 m 张空白牌, 他可以在上面…...
《Vue.js》阅读之响应式数据与副作用函数
Vue.js 《Vue.js设计与实现》(霍春阳) 适合:从零手写Vue3响应式系统,大厂面试源码题直接覆盖。重点章节:第4章(响应式)、第5章(渲染器)、第8章(编译器&…...
线下消费经济“举步维艰”,开源AI智能名片链动2+1+S2B2C小程序线上“狂飙突进”!
开源AI智能名片链动21模式S2B2C商城小程序:驱动消费经济迭代的数字化引擎 摘要:本文以中国消费经济四阶段演进为框架,分析开源AI智能名片链动21模式S2B2C商城小程序如何重构商业生态。研究显示,该系统通过AI算法驱动的精准需求匹…...
简述DNS域名服务器
DNS简述 在互联网中,识别一个主机通常有两种方式——主机名和IP地址。从人类角度来看,人类肯定更喜欢这些便于记忆的主机名标识方式,而对于路由器来说,路由器则更喜欢定长的,有结构层次的IP地址。所以DNS域名服务器就…...
小结: Port Security,DHCP Snooping,IPSG,DAI,
以下是华为和思科在 IP Source Guard、Dynamic ARP Inspection、DHCP Snooping、Port Security 四个安全功能的配置指令对比: 1. Port Security(端口安全) 思科(Cisco) # 进入接口模式 interface GigabitEthernet0/1…...
2025年阿里云ACP人工智能高级工程师认证模拟试题(附答案解析)
这篇文章的内容是阿里云ACP人工智能高级工程师认证考试的模拟试题。 所有模拟试题由AI自动生成,主要为了练习和巩固知识,并非所谓的 “题库”,考试中如果出现同样试题那真是纯属巧合。 1、在PAl-Studio实验运行完毕后,可以右键单…...
SwitchyOmega_Chromium 代理插件下载与配置
下载地址: 【免费】SwitchyOmega-Chromium.ran资源-CSDN文库 下载 SwitchyOmega_Chromium.ran 文件。 解压缩文件 解压第一层后,解压第二层代理插件SwitchyOmega_Chromium。 打开 Chromium 浏览器。 导入插件: 在浏览器地址栏输入 chrome://extensio…...
【Nova UI】十四、打造组件库之按钮组件(下):按钮组组件的构建之旅
序言 在之前的探索中,我们成功雕琢出了功能完备且样式精美的 Vue 按钮组件,它在前端界面上绽放着独特的光彩✨。然而,前端开发的创新之路永无止境。如今,为了满足更丰富的交互需求,我们将目光聚焦在按钮组组件的实现上…...
SQL注入
sql注入核心语句 information_schema 虚拟数据库(物理上不存在),能提供方皓文数据库元数据的方式,元数据是关于数据的数据,如数据库名、表名、列的数据类型、访问权限等 只能访问 information_schema下面的表: schemata表…...
Java面试高阶篇:Spring Boot+Quarkus+Redis高并发架构设计与性能优化实战
Java面试高阶篇:Spring BootQuarkusRedis高并发架构设计与性能优化实战 面试官(严肃): Q1: 你项目中如何实现高并发下的缓存优化? 候选人(水货): 我们用了Redis做缓存,…...
【CF】Day57——Codeforces Round 955 (Div. 2, with prizes from NEAR!) BCD
B. Collatz Conjecture 题目: 思路: 简单模拟 很简单的模拟,我们只需要快速的找到下一个离 x 最近的 y 的倍数即可(要大于 x) 这里我们可以这样写 add y - (x % y),这样就知道如果 x 要变成 y 的倍数还要…...
Matlab 列车纵向滑模二阶自抗扰算法和PID对比
1、内容简介 Matlab 223-列车纵向滑模二阶自抗扰算法和PID对比 可以交流、咨询、答疑 2、内容说明 略 列车模型 在运行过程中,已知列车受到牵引力或者制动力,基本阻力和附加阻力的作用,规定与列车运行方向相同的力为正,与运行…...
Swift实战:如何优雅地从二叉搜索树中挑出最接近的K个值
文章目录 摘要描述题解答案题解代码分析示例测试及结果时间复杂度空间复杂度总结未来展望 摘要 在日常开发中,我们经常会遇到“在一堆数据中找出最接近某个值”的需求。尤其在搜索引擎、推荐系统或者地理坐标匹配中,这种“最近匹配”的问题非常常见。Le…...
深度策略梯度算法PPO
一、策略梯度核心思想和原理 从时序差分算法Q学习到深度Q网络,这些算法都侧重于学习和优化价值函数,属于基于价值的强化学习算法(Value-based)。 1. 基于策略方法的主要思想(Policy-based) 基于价值类方…...
QuickList
Redis在3.2版本引入数据结构,是一个双端链表,每个节点都是一个ZipList。 引入的原因:ZipList申请内存空间是连续的,如果内存占用较多,申请内存效率很低 思想:属于分片存储的思想 Redis配置项:…...
DVWA在线靶场-SQL注入部分
目录 1.SQL注入 1.1 low 1.2 Medium 1.3 high 1.4 impossible 1. SQL盲注 1.1 low 2.2 medium 2.3 high 2.4 impossible 1.SQL注入 显注:前端页面可以回显用户信息,比如 联合注入、报错注入。 盲注:前端页面不能回显用户信息,比…...
IDEA+git将分支合并到主分支、IDEA合并分支
文章目录 一、合并分支二、可能遇到的问题2.1、代码冲突 开发过程中我们可能在开发分支(dev)中进行开发,等上线后将代码合并到主分支(master)中,本文讲解如何在IDEA中将dev分支的代码合并到master分支中。 一、合并分支 功能说明:将dev分支的…...
【Linux笔记】——进程信号的产生
🔥个人主页🔥:孤寂大仙V 🌈收录专栏🌈:Linux 🌹往期回顾🌹:【Linux笔记】进程间通信——system v 共享内存 🔖流水不争,争的是滔滔不 一、进程信号…...
Java后端文件类型检测(防伪造)
在 Spring Boot 项目中,为了防止用户伪造 Content-Type(例如将 .txt 文件改为 image/jpeg 上传),可以通过检查文件的 Magic Number(文件头签名)来验证文件的真实类型。以下是 详细实现步骤 和 完整代码示例…...
知名人工智能AI培训公开课内训课程培训师培训老师专家咨询顾问唐兴通AI在金融零售制造业医药服务业创新实践应用
AI赋能未来工作:引爆效率与价值创造的实战营 AI驱动的工作革命:从效率提升到价值共创 培训时长: 本课程不仅是AI工具的操作指南,更是面向未来的工作方式升级罗盘。旨在帮助学员系统掌握AI(特别是生成式AI/大语言模型…...
VUE3基础样式调整学习经验
首先创建一个vue项目最好要把不属于自己的样式都删除掉,以面出现css难以调整的情况: 1.assets目录下的main.css、base.css等样式全部删除 2.app.vue下的样式也全部删除 3.使用element plus一定要加入样式包: import element-plus/dist/in…...
AI与IoT携手,精准农业未来已来
AIoT:农业领域的变革先锋 在科技飞速发展的当下,人工智能(AI)与物联网(IoT)的融合 ——AIoT,正逐渐成为推动各行业变革的关键力量,农业领域也不例外。AIoT 技术通过将 AI 的智能分析能力与 IoT 的设备互联能力相结合,为农业生产带来了前所未有的精准度和智能化水平。 …...
物联网驱动的共享充电站系统:智能充电的实现原理与技术解析!
随着新能源汽车的快速普及,共享充电站系统作为其核心基础设施,正通过物联网技术的深度赋能,实现从“传统充电”到“智能充电”的跨越式升级。本文将从系统架构、核心技术、优化策略及实际案例等角度,解析物联网如何驱动共享充电站…...
MCP 入门实战:用 C# 开启 AI 新篇章
MCP 入门实战:用 C# 开启 AI 新篇章 一、什么是 MCP? MCP,全称为 Model Context Protocol(模型上下文协议),是一个开放的协议,它为应用程序向大型语言模型(LLM)提供上下…...
ES常识7:ES8.X集群允许4个 master 节点吗
在 Elasticsearch(ES)中,4 个 Master 节点的集群可以运行,但存在稳定性风险,且不符合官方推荐的最佳实践。以下从选举机制、故障容错、资源消耗三个维度详细分析: 一、4 个 Master 节点的可行性࿱…...
WebRTC:去中心化网络P2P框架解析
在互联网的世界里,数据的传输就像一场永不停歇的 “信息快递”。当我们使用 WebRTC 实现视频通话时,背后支撑的网络框架至关重要。今天,我们将深入探索 WebRTC 开发中视频通话的前置基础 ——P2P(点对点)框架ÿ…...
Linux 上安装RabbitMQ
🐇 安装 Erlang/OTP 27.3.4(最新稳定版) 1. 下载 Erlang 源码 cd /usr/local/src wget https://erlang.org/download/otp_src_27.3.4.tar.gz2. 解压源码 tar -zxvf otp_src_27.3.4.tar.gz cd otp_src_27.3.43. 安装依赖 sudo apt update …...
Service Mesh实战之Istio
Service Mesh(服务网格)是一种专为微服务架构设计的网络代理层,用于处理服务间的通信、管理和监控。Istio 是一个流行的开源 Service Mesh 实现,通过提供流量管理、观测性和安全性等功能,帮助开发者应对分布式系统的复…...
BGP练习
一、要求拓扑图 二、要求 完成上图内容,要求五台路由器的环回地址均可以相互访问 三、需求分析 1. 网络连通性目标 - 需求明确要求五台路由器(AR1 - AR5 )的环回地址能够相互访问。环回地址是路由器上用于测试、管理及作为BGP等协议中Ro…...
【Redis】分布式锁的实现
目录 一、本地锁存在的问题 二、redis实现分布式锁原理 三、使用示例 四、锁误删问题 解决思路 获取锁和释放锁代码优化 五、锁释放的原子性问题 解决思路(Lua脚本) 使用流程 总结 大家好,我是千语。上期给大家讲了使用悲观锁来解决…...
【vue】全局组件及组件模块抽离
一、全局组件 只要是实例化过的区域都可以使用 Vue.component("组件名",{ template: 内容} ) 二、组件模块抽离 抽离就是把template的内容写到body里面,然后建立id写到变量下的template里,id变量写到component里 body{ template: …...
手写 vue 源码 === watch 实现
目录 1. watch 的基本使用 2. watch 的整体架构 3. doWatch 函数的实现 3.1 处理不同类型的监听源 3.2 清理副作用的机制 3.3 创建响应式效果 3.4 初始化执行 3.5 返回停止函数 4. watch 如何基于 ReactiveEffect 实现 4.1 依赖收集过程详解 4.2 更新触发过程详解 …...
STM32核心机制解析:重映射、时间片与系统定时器实战——从理论到呼吸灯开发
知识点1【重映射的概念】 1、引入 默认: **定义:**系统或硬件在未经用户修改时的预设配置或行为 STM32的引脚功能、外设配置、中断向量表等默认由芯片设计或库函数预设。 部分重映射 **定义:**仅修改部分资源或地址的映射关系ÿ…...
【Linux网络编程】HTTPS协议原理
目录 一,HTTPS是什么? 1,什么是加密? 2,为什么需要加密? 3,常见的加密方式 对称加密 非对称加密 4,数据摘要&&数据指纹 二,HTTPS协议加密方案 方案一&a…...