第二章:一致性基础 A Primer on Memory Consistency and Cache Coherence - 2nd Edition
在本章中,我们将介绍足够多的缓存一致性知识,以便理解一致性模型是如何与缓存相互作用的。我们在 2.1 节首先给出在本入门教程中所考虑的系统模型。为了简化本章以及后续章节的阐述,我们选择了尽可能简单的系统模型,该模型足以说明重要的问题;而将与更复杂系统模型相关的问题留到第 9 章讨论。
2.2 节解释了必须解决的缓存一致性问题,以及不一致情况是如何产生的。2.3 节则精确地定义了缓存一致性。
2.1 基线系统模型
在本入门教程中,我们考虑的是具有多个共享内存的处理器核心的系统。也就是说,所有核心都可以对所有(物理)地址执行加载和存储操作。基线系统模型包括一个单芯片多核处理器和片外主内存,如图 2.1 所示。多核处理器芯片由多个单线程核心组成,每个核心都有自己的私有数据缓存,以及一个由所有核心共享的末级缓存(LLC)。在本入门教程中,当我们使用 “缓存” 一词时,指的是核心的私有数据缓存,而不是末级缓存。每个核心的数据缓存使用物理地址进行访问,并且是回写式的。核心和末级缓存通过互连网络相互通信。尽管末级缓存位于处理器芯片上,但在逻辑上它是一个 “内存侧缓存”,因此不会引入另一层一致性问题。在逻辑上,末级缓存就在内存之前,用于降低内存访问的平均延迟并提高内存的有效带宽。末级缓存还充当片上内存控制器。
这个基线系统模型省略了许多常见但在本入门教程的大部分内容中并非必需的特性。这些特性包括指令缓存、多级缓存、多个核心共享的缓存、虚拟地址缓存、转换后备缓冲器(TLB)以及一致性直接内存访问(DMA)。基线系统模型还排除了存在多个多核芯片的可能性。我们稍后会讨论所有这些特性,但目前,它们会增加不必要的复杂性。
2.2 问题:不一致情况可能如何发生
不一致情况的出现仅仅是因为一个基本问题:存在多个可以访问缓存和内存的参与者。在现代系统中,这些参与者包括处理器核心、DMA 引擎以及可以对缓存和内存进行读写操作的外部设备。在本入门教程的其余部分,我们通常关注的参与者是核心,但值得记住的是,可能还存在其他参与者。
表 2.1 展示了一个不一致的简单示例。最初,内存位置 A 在内存以及两个核心的本地缓存中都存储着值 42。在时刻 1,核心 1 将其缓存中内存位置 A 的值从 42 更改为 43,这使得核心 2 缓存中 A 的值变得过时。核心 2 执行一个 while 循环,反复从其本地缓存中加载(过时的)A 的值。显然,这是一个不一致的例子,因为核心 1 的存储操作对核心 2 来说不可见,结果导致核心 2 陷入 while 循环中。
为了防止不一致,系统必须实现一个缓存一致性协议,使得核心 1 的存储操作对核心 2 可见。这些缓存一致性协议的设计和实现是第 6 至 9 章的主要内容。
2.3 缓存一致性接口
大致来说,一致性协议必须确保写操作对所有处理器都可见。在本节中,我们将通过一致性协议所暴露的抽象接口来更正式地理解一致性协议。
处理器核心通过一个一致性接口(图 2.2)与一致性协议进行交互,该接口提供两种方法:(1)一个读请求方法,该方法以一个内存位置作为参数并返回一个值;(2)一个写请求方法,该方法以一个内存位置和一个(要写入的)值作为参数,并返回一个确认信息。
文献中出现过许多一致性协议,并且这些协议也已在实际处理器中得到应用。我们根据一致性接口的性质将这些协议分为两类 —— 具体来说,是根据一致性与一致性模型是否有清晰的分离,或者它们是否不可分割来划分。
与一致性无关的一致性。在第一类中,写操作在返回之前会对所有其他核心可见。由于写操作是同步传播的,第一类所呈现的接口与原子内存系统(无缓存)的接口相同。因此,与一致性协议交互的任何子系统(例如处理器核心流水线)都可以假设它正在与一个没有缓存的原子内存系统进行交互。从一致性实施的角度来看,这个一致性接口实现了关注点的良好分离。缓存一致性协议完全抽象掉了缓存,并呈现出原子内存的假象 —— 就好像缓存被移除了,只有内存包含在一致性模块中(图 2.2)—— 而处理器核心流水线则执行由一致性模型规范所规定的顺序。
一致性导向的一致性。在较新的第二类中,写操作是异步传播的 —— 因此,写操作可以在对所有处理器可见之前就返回,从而允许观察到(实时的)过时值。然而,为了正确地实施一致性,这类一致性协议必须确保写操作最终可见的顺序符合一致性模型所规定的顺序规则。再参考图 2.2,流水线和一致性协议都执行由一致性模型所规定的顺序。这第二类协议的出现是为了支持基于吞吐量的通用图形处理单元(GP-GPU),并且在本入门教程第一版出版后得到了广泛关注。
本入门教程(以及本章的其余部分)主要关注第一类一致性协议。我们将在异构一致性(第 10 章)的背景下讨论第二类一致性协议。
2.4 (与一致性无关的)一致性不变量
一个一致性协议必须满足哪些不变量,才能使缓存不可见并呈现出原子内存系统的抽象呢?
在教科书和已发表的论文中出现过多种关于一致性的定义,我们并不想介绍所有这些定义。相反,我们给出我们更倾向的定义,因为它有助于深入理解一致性协议的设计。在侧边栏中,我们将讨论其他定义以及它们与我们偏好的定义之间的关系。
我们通过单写者 - 多读者(SWMR)不变量来定义一致性。对于任何给定的内存位置,在任何给定的时刻,要么存在单个核心可以对其进行写入(并且也可以读取),要么存在若干核心可以对其进行读取。因此,永远不会出现这样的情况:一个给定的内存位置在同一时刻可以被一个核心写入,而同时又被其他任何核心读取或写入。另一种理解这个定义的方式是,对于每个内存位置,将其生命周期划分为多个时期。在每个时期内,要么单个核心具有读写访问权限,要么若干核心(可能为零个)具有只读访问权限。图 2.3 展示了一个示例内存位置的生命周期,划分为四个保持 SWMR 不变量的时期。
除了 SWMR 不变量之外,一致性还要求正确传播给定内存位置的值。为了解释为什么值很重要,让我们重新考虑图 2.3 中的示例。即使 SWMR 不变量成立,但如果在第一个只读时期,核心 2 和核心 5 读取到的值不同,那么系统就是不一致的。同样,如果核心 1 在其读写时期未能读取到核心 3 写入的最后一个值,或者核心 1、核心 2 或核心 3 在核心 1 的读写时期未能读取到核心 1 执行的最后一次写入,那么系统也是不一致的。
因此,一致性的定义必须在 SWMR 不变量的基础上增加一个数据值不变量,该不变量与值如何从一个时期传播到下一个时期有关。这个不变量表明,一个内存位置在一个时期开始时的值与它在上一个读写时期结束时的值相同。
还有其他与这些不变量等价的解释。一个值得注意的例子 [5] 从令牌的角度解释了 SWMR 不变量。这些不变量如下。对于每个内存位置,存在固定数量的令牌,其数量至少与核心的数量一样多。如果一个核心拥有所有令牌,它就可以写入该内存位置。如果一个核心拥有一个或多个令牌,它就可以读取该内存位置。因此,在任何给定的时间,不可能出现一个核心正在写入内存位置,而其他任何核心正在读取或写入该位置的情况。
一致性不变量
____________________________________________________________
1. 单写者、多读者(SWMR)不变量。对于任何内存位置 A,在任何给定的时间,要么只存在单个核心可以对 A 进行写入(并且也可以读取),要么存在若干核心只能对 A 进行读取。
2. 数据值不变量。一个内存位置在一个时期开始时的值与它在上一个读写时期结束时的值相同。
_____________________________________________________________
2.4.1 维护一致性不变量
上一节中给出的一致性不变量为一致性协议的工作原理提供了一些思路。绝大多数一致性协议,称为 “无效化协议”,都是专门为维护这些不变量而设计的。如果一个核心想要读取一个内存位置,它会向其他核心发送消息以获取该内存位置的当前值,并确保没有其他核心以读写状态缓存了该内存位置的副本。这些消息结束任何正在进行的读写时期,并开始一个只读时期。如果一个核心想要写入一个内存位置,它会向其他核心发送消息以获取该内存位置的当前值(如果它还没有有效的只读缓存副本),并确保没有其他核心以只读或读写状态缓存了该内存位置的副本。这些消息结束任何正在进行的读写或只读时期,并开始一个新的读写时期。
本入门教程中关于缓存一致性的章节(第 6 至 9 章)将大大扩展对无效化协议的这种抽象描述,但基本思路是相同的。
2.4.2 一致性的粒度
一个核心可以以各种粒度执行加载和存储操作,通常范围从 1 到 64 字节。从理论上讲,一致性可以在最细的加载 / 存储粒度上实现。然而,在实践中,一致性通常是在缓存块的粒度上维护的。也就是说,硬件以缓存块为基础来强制实施一致性。在实践中,SWMR 不变量很可能是,对于任何内存块,要么存在单个写者,要么存在若干读者。在典型系统中,不可能出现一个核心正在写入一个块的第一个字节,而另一个核心正在写入该块内的另一个字节的情况。尽管缓存块粒度很常见,并且在本入门教程的其余部分我们也假定是这种情况,但应该注意的是,已经有一些协议在更细或更粗的粒度上维护一致性。
侧边栏:类似内存一致性的缓存一致性定义
——————————————————————————————————————————
我们偏好的一致性定义是从实现的角度来定义它的 —— 指定了关于不同核心对内存位置的访问权限以及核心之间传递的数据值的硬件强制不变量。
还存在另一类从程序员的角度来定义一致性的定义,类似于内存一致性模型如何指定从体系结构上可见的加载和存储操作的顺序。
一种类似一致性的指定一致性的方法与顺序一致性的定义相关。顺序一致性(SC)是我们将在第 3 章深入讨论的一种内存一致性模型,它规定系统必须以一种尊重每个线程的程序顺序的全序方式来执行所有线程对所有内存位置的加载和存储操作。每个加载操作获取在该全序中最近的存储操作的值。与顺序一致性定义类似的一致性定义是,一个一致的系统必须以一种尊重每个线程的程序顺序的全序方式来执行所有线程对单个内存位置的加载和存储操作。这个定义突出了文献中一致性和一致性之间的一个重要区别:一致性是在每个内存位置的基础上指定的,而一致性是针对所有内存位置指定的。值得注意的是,任何满足 SWMR 和数据值不变量(再结合一个不会对任何特定位置的访问进行重新排序的流水线)的一致性协议也保证满足这种类似一致性的一致性定义。(然而,反之不一定成立。)
另一个 [1, 2] 关于一致性的定义用两个不变量来定义一致性:(1)每个存储操作最终对所有核心都可见;(2)对同一内存位置的写入操作是按顺序执行的(即所有核心以相同的顺序观察到这些操作)。IBM 在 Power 架构 [4] 中也持有类似的观点,部分原因是为了便于实现这样一种情况:一个核心的一系列存储操作可能已经到达了某些核心(这些核心的加载操作可以看到这些值),但还没有到达其他核心。不变量 2 与我们前面描述的类似一致性的定义等价。与不变量 2(这是一个安全性不变量,即不能发生不好的事情)不同,不变量 1 是一个活性不变量(即好的事情最终必须发生)。
另一个由 Hennessy 和 Patterson [3] 指定的一致性定义由三个不变量组成:(1)一个核心对内存位置 A 的加载操作获取该核心之前对 A 的存储操作的值,除非在这期间另一个核心对 A 进行了存储操作;(2)如果另一个核心对 A 的存储操作 S 与该加载操作 “在时间上足够分开”,并且在 S 和该加载操作之间没有发生其他存储操作,那么对 A 的加载操作获取另一个核心对 A 的存储操作 S 的值;(3)对同一内存位置的存储操作是按顺序执行的(与前一个定义中的不变量 2 相同)。与前一个定义一样,这组不变量既包含了安全性又包含了活性。
—————————————————————————————————————————————
2.4.3 一致性在何时相关
无论我们选择哪种一致性定义,它都只在某些情况下相关,架构师必须清楚它在何时适用,何时不适用。我们现在讨论两个重要的问题。
・一致性适用于所有保存来自共享地址空间的块的存储结构。这些结构包括一级数据缓存、二级缓存、共享末级缓存(LLC)和主内存。这些结构还包括一级指令缓存和转换后备缓冲器(TLB)。
・一致性对程序员来说不是直接可见的。相反,处理器流水线和一致性协议共同执行一致性模型 —— 并且只有一致性模型对程序员是可见的。
相关文章:
第二章:一致性基础 A Primer on Memory Consistency and Cache Coherence - 2nd Edition
在本章中,我们将介绍足够多的缓存一致性知识,以便理解一致性模型是如何与缓存相互作用的。我们在 2.1 节首先给出在本入门教程中所考虑的系统模型。为了简化本章以及后续章节的阐述,我们选择了尽可能简单的系统模型,该模型足以说明…...
C++类_移动构造函数
std::move 的主要用途是在对象所有权转移时,触发移动构造函数或移动赋值运算符,避免不必要的深拷贝,提升性能。 移动构造函数 和 移动赋值运算符, std::move转换为右值,匹配到移动构造函数和移动赋值运算符。…...
Spring AI 实战:第一章、Spring AI入门之DeepSeek调用
引言:当Spring遇上AI,会擦出怎样的火花? 作为一名Java开发者,是否曾经眼红Python阵营那些花里胡哨的AI应用?是否在对接各种大模型API时,被五花八门的接口规范搞得头大?好消息是,Spr…...
fastapi+vue中的用户权限管理设计
数据库设计:RBAC数据模型 这是一个典型的基于SQLAlchemy的RBAC权限系统数据模型实现,各模型分工明确,共同构成完整的权限管理系统。 图解说明: 实体关系: 用户(USER)和角色(ROLE)通过 USER_ROLE 中间表实现多对多关系…...
Space Engineers 太空工程师 [DLC 解锁] [Steam] [Windows]
Space Engineers 太空工程师 [DLC 解锁] [Steam] [Windows] 需要有游戏正版基础本体,安装路径不能带有中文,或其它非常规拉丁字符; DLC 版本 至最新全部 DLC 后续可能无法及时更新文章,具体最新版本见下载文件说明 DLC 解锁列表&…...
随机变量数字特征
主要介绍一维随机变量期望和方差、二维随机变量期望和方差、以及协方差相关公式,及推导。 一维随机变量 以一个抛硬币的场景作为例子,如下: 抛掷两枚均匀硬币,如果两枚都是正面向上,则赢得2元,否则就输掉…...
C++总结01-类型相关
一、数据存储 1.程序数据段 • 静态(全局)数据区:全局变量、静态变量 • 堆内存:程序员手动分配、手动释放 • 栈内存:编译器自动分配、自动释放 • 常量区:编译时大小、值确定不可修改 2.程序代码段 •…...
【多线程】七、POSIX信号量 环形队列的生产者消费者模型
文章目录 Ⅰ. 信号量一、POSIX 信号量的概念二、POSIX 信号量的类型区别三、POSIX 信号量与 SystemV 信号量的区别Ⅱ. 线程信号量基本原理一、为什么要引入信号量❓二、PV 操作三、POSIX 信号量的实现原理四、CAS操作介绍Ⅲ. POSIX未命名信号量接口一、初始化无名信号量二、销毁…...
二维码批量识别—混乱多张二维码识别-物品分拣—-未来之窗-仙盟创梦IDE
仙盟模型 用途 精准分拣:快速准确识别物品上复杂或多个二维码,依据码中信息(如目的地、品类等)实现物品自动化分拣,提高分拣效率与准确性。库存管理:识别入库、出库物品二维码,更新库存数据&am…...
《TensorFlow 与 TensorFlow Lite:协同驱动 AI 应用全景》
《TensorFlow 与 TensorFlow Lite:协同驱动 AI 应用全景》 摘要 :在机器学习技术浪潮中,TensorFlow 与 TensorFlow Lite 作为 Google 技术栈的核心组件,分别占据云端训练与端侧部署的关键位置。本文将系统梳理二者架构特性、功能…...
Spring AI 实战:第三章、Spring AI结构化输出之告别杂乱无章
引言:当程序员遇上剧荒 “周末看什么?” 这个看似简单的问题,往往能让我们在各大影视平台间反复横跳半小时,最后无奈选择重刷《老友记》。本期让我们用技术解决这个"世纪难题":让大模型成为你的私人影视推荐…...
ros2 humble 控制真实机械臂(以lerobot为例)
基础版 0.确保串口访问权限 sudo chmod 666 /dev/ttyARM0 # 确保串口访问权限 1.下载 lerobot 驱动功能包 git clone https://gitee.com/kong-yue1/lerobot_devices.git 2.编写控制节点(完整代码) 主要功能是与 Feetech 电机总线进行通信&#…...
REINFORCE蒙特卡罗策略梯度算法详解:python从零实现
🧠 向所有学习者致敬! “学习不是装满一桶水,而是点燃一把火。” —— 叶芝 我的博客主页: https://lizheng.blog.csdn.net 🌐 欢迎点击加入AI人工智能社区! 🚀 让我们一起努力,共创…...
模拟SIP终端向Freeswitch注册用户
1、简介 使用go语言编写一个程序,模拟SIP-T58终端在Freeswitch上注册用户 2、思路 以客户端向服务端Freeswitch发起REGISTER请求,告知服务器当前的联系地址构造SIP REGISTER请求 创建UDP连接,连接到Freeswitch的5060端口发送初始的REGISTER请…...
Elasticsearch 中的索引模板:如何使用可组合模板
作者:来自 Elastic Kofi Bartlett 探索可组合模板以及如何创建它们。 更多阅读: Elasticsearch:可组合的 Index templates - 7.8 版本之后 想获得 Elastic 认证吗?查看下一期 Elasticsearch Engineer 培训的时间! El…...
一篇文章看懂时间同步服务
Linux 系统时间与时区管理 一、时间与时钟类型 时钟类型说明管理工具系统时钟由 Linux 内核维护的软件时钟,基于时区配置显示时间timedatectl硬件时钟 (RTC)主板上的物理时钟,通常以 UTC 或本地时间存储,用于系统启动时初始化时间hwclock …...
Mysql常用语句汇总
Mysql语句分类 DDL: 数据定义语言,用来定义数据库对象(数据库、表、字段)DML: 数据操作语言,用来对数据库表中的数据进行增删改DQL: 数据查询语言,用来查询数据库中表的记录DCL: 数据控制语言,用来创建数据…...
迭代器的思想和实现细节
1. 迭代器的本质 迭代器是一种行为类似指针的对象,它可能是指针(如 std::vector 的迭代器),也可能是封装了指针的类(如 std::list 的迭代器)。如果是指针那天然就可以用下面的运算,如果是类&am…...
[Vue]编程式导航
在 Vue 中,编程式导航是通过 JavaScript 代码(而非 <router-link> 标签)动态控制路由跳转的核心方式。这个方法依赖于 Vue Router 提供的 API,能更灵活地处理复杂场景(如异步操作、条件跳转等)。 一、…...
使用Node.js搭建https服务器
一、引言 https是是http的安全版本,在http的基础上通过传输加密和身份认证保证了传输过程中的安全性。可以认为:https http tls/ssl。本文讲述使用Node.js搭建https服务器的方法。 二、编译OpenSSL 按照《Openssl在Linux下编译/交叉编译》࿰…...
网络安全:sql注入练习靶场——sqli_labs安装保姆级教程
网络安全:sql注入练习靶场——sqli_labs安装保姆级教程 前言 sqli-labs靶场是一个开源的sql注入练习的综合靶场,包含大部分sql注入漏洞以及注入方式 网络安全学习者可以通过在sqli-labs靶场练习提升对sql注入的理解,以及学习各种绕过姿势。…...
rfsoc petalinux适配调试记录
1。安装虚拟机 2.设置共享文件夹 https://xinzhi.wenda.so.com/a/1668239544201149先设置文件夹路径 vmware 12 下安装 ubuntu 16.04 后,按往常的惯例安装 vmware-tools,安装时提示建议使用 open-vm-tools,于是放弃 vmware-tools 的安装&am…...
Windows下编译WebRTC源码
一、开发环境要求 准备一台64位的win10或win11(我用的是win11)电脑。最好是一台纯净的、没有安装过其它软件的Windows主机,避免已安装的软件和库对编译造成影响。 然后最好预留超过100G的硬盘空间。因为编译WebRTC时会产生大量的临时文件需…...
【vscode】.dart文件没有错误波浪线
解决方法: 新建一个文件夹,在vscode里打开这个文件夹 在这个文件夹里新建.dart文件后打开即可出现错误波浪线...
OpenharmonyOS+RK3568,【编译烧录】
文章目录 1. 摘要 ✨2. 代码下载 📩3. 编译 🖥️4. 修改&适配 ✂️4.1 编译框架基本概念4.2 vendor & device 目录4.3 内核编译4.3.1 如何修改、适配自己的开发板? 4.4 修改外设驱动 5. 烧录&验证 📋参考 1. 摘要 ✨ …...
从零开始理解 C++ 后端编程中的分布式系统
一、什么是“分布式”? 简单来说,分布式系统就是由“多个计算机(或服务器)”组成的一个大系统,它们通过网络协作完成某个任务,就像一个“团队合作”一样。 想象你开了一家餐馆,最初只有 一个厨房 和 一个服务员,所有订单都在这里处理。随着生意变好,你需要: 开分店…...
基于SpringBoot的篮球竞赛预约平台设计与实现
1.1 研究背景 科学技术日新月异的如今,计算机在生活各个领域都占有重要的作用,尤其在信息管理方面,在这样的大背景下,学习计算机知识不仅仅是为了掌握一种技能,更重要的是能够让它真正地使用到实践中去,以…...
具身系列——PPO算法实现CartPole游戏(强化学习)
完整代码参考: https://gitee.com/chencib/ailib/blob/master/rl/ppo_cartpole.py 执行结果: 部分训练得分: (sd) D:\Dev\traditional_nn\feiai\test\rl>python ppo_cartpole_v2_succeed.py Ep: 0 | Reward: 23.0 | Running: 2…...
小程序与快应用:中国移动互联网的渐进式革命——卓伊凡的技术演进观
小程序与快应用:中国移动互联网的渐进式革命——卓伊凡的技术演进观 在知乎看到很多:“懂王”发布的要把内行笑疯了的评论,卓伊凡必须怼一下,真印证那句话,无知者无畏 一、Web与小程序的技术本质差异 1.1 浏览器渲染…...
Socket 编程 UDP
Socket 编程 UDP UDP 网络编程V1 版本 - echo serverV2 版本 - DictServerV3 版本 - 简单聊天室 补充参考内容地址转换函数关于 inet_ntoa UDP 网络编程 声明:下面代码的验证都是用Windows作为客户端的,如果你有两台云服务器可以直接粘贴我在Linux下的客…...
Lua 基础 API与 辅助库函数 中关于创建的方法用法
目录 基础 API 函数1. lua_len(L, index)2. lua_load(L, reader, data, chunkname, mode)3. lua_newstate(allocator, ud)4. lua_newtable(L)5. lua_newthread(L)6. lua_newuserdata(L, size)7. lua_next(L, index) 辅助库函数(luaL_*)8. luaL_len(L, in…...
YOLOv11改进:利用RT-DETR主干网络PPHGNetV2助力轻量化目标检测
这里写自定义目录标题 YOLOv11改进:利用RT-DETR主干网络PPHGNetV2助力轻量化目标检测1. 介绍2. 引言3. 技术背景3.1 YOLOv11概述3.2 RT-DETR与PPHGNetV23.3 相关工作 4. 应用使用场景5. 详细代码实现5.1 环境准备5.2 PPHGNetV2主干网络实现5.3 YOLOv11与PPHGNetV2集…...
centos7.0无法安装php8.2/8.3
在centos安装php8.2报错 configure: error: *** A compiler with support for C17 language features is required. 配置过程检测到你的系统编译器不支持 C17 语言特性,而 PHP 8.2 的编译需要编译器支持 C17 sudo yum update -y sudo yum install centos-releas…...
工业传动核心部件深度剖析:丝杆升降机与气缸的技术特性及选型指南
在工业自动化技术飞速发展的当下,丝杆升降机与气缸作为关键的直线传动部件,广泛应用于各类机械设备中。对于工程师而言,深入了解它们的技术特性、优缺点及适用场景,是实现高效、精准设备设计的重要前提。本文将从技术原理出发&…...
flask 获取各种请求数据:GET form-data x-www-form-urlencoded JSON headers 上传文件
在 Flask 里,能使用多种方法获取不同类型的请求数据,下面详细介绍常见请求数据的获取方式。 获取查询字符串参数(GET 请求) 查询字符串参数一般在 URL 里,以 ?key1value1&key2value2 这种形式存在。可通过 requ…...
c++_2011 NOIP 普及组 (1)
P1307 [NOIP 2011 普及组] 数字反转 P1307 [NOIP 2011 普及组] 数字反转 - 洛谷 # P1307 [NOIP 2011 普及组] 数字反转 ## 题目描述 给定一个整数 $N$,请将该数各个位上数字反转得到一个新数。新数也应满足整数的常见形式,即除非给定的原数为零&…...
信息泄露:网站敏感文件泄漏的隐形危机与防御之道
在网络安全领域,信息泄露常被称为“沉默的杀手”。攻击者无需复杂漏洞,仅通过网站无意暴露的敏感文件(如源码备份、配置文件、版本控制记录),即可获取数据库密码、API密钥甚至服务器权限。本文将深入剖析信息泄…...
C++笔记-多态(包含虚函数,纯虚函数和虚函数表等)
1.多态的概念 多态(polymorphism)的概念:通俗来说,就是多种形态。多态分为编译时多态(静态多态)和运行时多态(动态多态),这里我们重点讲运行时多态,编译时多态(静态多态)和运行时多态(动态多态)。编译时多态(静态多态)主要就是我们前面讲的函…...
2025年- H22-Lc130-206. 反转链表(链表)---java版
1.题目描述 2.思路 使用迭代法 (1)定义一个前指针 (2)然后定义两个变量 curr(head),curr.next。 (3)curr和curr.next交换位置(只要当前指针不为空,执行两两交换) 3.代码实现 /*** Definition for singly-…...
智能家居的OneNet云平台
一、声明 该项目只需要创建一个产品,然后这个产品里面包含几个设备,而不是直接创建几个产品 注意:传输数据使用到了不同的power,还有一定要手机先联网才能使用云平台 二、OneNet云平台创建 (1)Temperatur…...
二、shell脚本--变量与数据类型
1. 变量的定义与使用 定义变量:简单直接 在 Shell 里定义变量相当容易: 基本格式: variable_namevalue关键点 ❗:赋值号 的两边绝对不能有空格!这绝对是初学者最容易踩的坑之一 😨,务必留意!…...
GitHub Actions 和 GitLab CI/CD 流水线设计
以下是关于 GitHub Actions 和 GitLab CI/CD 流水线设计 的基本知识总结: 一、核心概念对比 维度GitHub ActionsGitLab CI/CD配置方式YAML 文件(.github/workflows/*.yml).gitlab-ci.yml执行环境GitHub 托管 Runner / 自托管GitLab 共享 Runner / 自托管市场生态Actions Mar…...
穿越数据森林与网络迷宫:树与图上动态规划实战指南
在 C 算法的浩瀚宇宙中,树与图就像是神秘的迷宫和茂密的森林,充满了未知与挑战。而动态规划则是我们探索其中的神奇罗盘,帮助我们找到最优路径。今天,就让我们一起深入这片神秘领域,揭开树与图上动态规划的神秘面纱&am…...
Java学习手册:Spring 生态其他组件介绍
一、微服务架构相关组件 Spring Cloud 服务注册与发现 : Eureka :由 Netflix 开源,包含 Eureka Server 和 Eureka Client 两部分。Eureka Server 作为服务注册表,接收服务实例的注册请求并管理其信息;Eureka Client 负…...
[android]MT6835 Android 移植brctl指令
说明 android默认brctl不支持showmacs选项,需要移植brctl-utils软件包 移除toybox中brctl编译 mssi/external/toybox/Android.bp 将 toybox_symlinks ["[","acpi","base64","basename","blockdev","br…...
安卓基础(悬浮窗分级菜单和弹窗)
initializeViews() 初始化 把全部的按钮都弄出来 // 主菜单按钮ImageButton mainButton floatingMenuView.findViewById(R.id.main_button);// 二级菜单按钮subButtons new ImageButton[3];subButtons[0] floatingMenuView.findViewById(R.id.sub_button_1);subButtons[1]…...
HTTP基础介绍+OSI七层参考模型+HTTP协议介绍
图片来源于网络 图片来源于网络 浏览器 Chrome:谷歌浏览器,推荐 Safari(WebKit):苹果浏览器,iOS,macOS Firefox:火狐浏览器,开源插件特别多(FireBug) IE:Wi…...
【项目实践】boost 搜索引擎
1. 项目展示 boost搜索引擎具体讲解视频 2. 项目背景 对于boost库,官方是没有提供搜索功能的,我们这个项目就是来为它添加一个站内搜索的功能。 3. 项目环境与技术栈 • 项目环境: ubuntu22.04、vscode • 技术栈: C/C、C11、S…...
接口隔离原则(ISP)
非常好,**接口隔离原则(ISP: Interface Segregation Principle)是 SOLID 五大原则中的第四个,它专门解决“一个接口太臃肿”**导致的麻烦。 我来从以下几个维度详细拆解: 🧠 什么是接口隔离原则࿱…...
Leetcode刷题记录29——矩阵置零
题源:https://leetcode.cn/problems/set-matrix-zeroes/description/?envTypestudy-plan-v2&envIdtop-100-liked 题目描述: 思路一: 💡 解题思路 本题中我们采用如下策略: 第一次遍历整个矩阵,记…...