当前位置: 首页 > news >正文

C++并发编程之内存顺序一致性

std::memory_order_seq_cst 是 C++11 引入的内存模型中的一种内存顺序(memory order),全称为 Sequential Consistency(顺序一致性)。它是 C++ 中最严格的内存顺序,提供了最强的同步保证。下面详细解释其含义、意图、作用以及适用场合,并通过示例来说明。


1. std::memory_order_seq_cst 的含义

std::memory_order_seq_cst 表示 顺序一致性,这意味着:

  1. 全局顺序一致性:所有线程看到的操作顺序是一致的。换句话说,所有使用 std::memory_order_seq_cst 的原子操作(包括 loadstoreread-modify-write)在所有线程中表现出相同的执行顺序。
  2. 先发生关系(happens-before):在同一线程中,操作之间的 happens-before 关系是显式的,而在不同线程之间,操作的顺序也是一致的。

简单来说,std::memory_order_seq_cst 保证程序的执行顺序与代码的顺序一致,且在所有线程中观察到的顺序是相同的。


2. 意图和作用

std::memory_order_seq_cst 的主要作用是:

  1. 简化多线程编程模型:它提供了类似单线程的执行顺序,使得开发者可以更容易地理解和推理多线程程序的行为。
  2. 强制全局顺序:确保所有线程都能看到相同的全局内存操作顺序,从而避免复杂的同步问题。
  3. 原子操作的强一致性:在原子操作中使用 std::memory_order_seq_cst 时,所有线程都会看到一致的内存状态。

3. 适用场合

std::memory_order_seq_cst 适用于以下场景:

  1. 需要强一致性:当你需要确保所有线程都看到相同的全局内存操作顺序时,使用 std::memory_order_seq_cst。例如,在需要严格同步的场景中(如计数器、屏障或临界区)。
  2. 简化推理:在多线程同步逻辑比较简单且不需要考虑性能优化的场景中,使用 std::memory_order_seq_cst 可以简化程序的推理和调试。
  3. 临界区保护:在需要确保临界区操作的顺序一致性时,使用 std::memory_order_seq_cst

4. 示例说明

示例 1:简单的计数器

假设我们有一个共享的计数器,多个线程会并发地对其进行自增操作。我们希望确保所有线程都能看到一致的全局顺序。

#include <atomic>
#include <iostream>
#include <thread>std::atomic<int> counter{0};void increment() {for (int i = 0; i < 1000; ++i) {counter.fetch_add(1, std::memory_order_seq_cst); // 使用顺序一致性}
}int main() {std::thread t1(increment);std::thread t2(increment);t1.join();t2.join();std::cout << "Counter: " << counter.load(std::memory_order_seq_cst) << std::endl;return 0;
}

说明

  • counter.fetch_add(1, std::memory_order_seq_cst) 使用 std::memory_order_seq_cst,确保所有线程看到的计数器自增顺序是一致的。
  • 最终的 counter.load(std::memory_order_seq_cst) 也使用 std::memory_order_seq_cst,确保所有线程都能看到一致的最终结果。
示例 2:双检查锁(不推荐)

虽然 std::memory_order_seq_cst 可以用于双检查锁模式的实现,但由于其开销较大,通常不推荐在这种场景中使用。不过,我们可以用它来展示效果。

#include <atomic>
#include <mutex>
#include <iostream>class Singleton {
public:static Singleton* instance() {auto* tmp = instance_.load(std::memory_order_seq_cst);if (tmp == nullptr) {std::lock_guard<std::mutex> lock(mutex_);tmp = instance_.load(std::memory_order_seq_cst);if (tmp == nullptr) {tmp = new Singleton();instance_.store(tmp, std::memory_order_seq_cst);}}return tmp;}private:Singleton() = default;~Singleton() = default;static std::atomic<Singleton*> instance_;static std::mutex mutex_;
};std::atomic<Singleton*> Singleton::instance_{nullptr};
std::mutex Singleton::mutex_;int main() {Singleton* s = Singleton::instance();std::cout << "Singleton instance created." << std::endl;return 0;
}

说明

  • 在双检查锁模式中,我们使用 std::memory_order_seq_cst 来确保所有线程看到的 instance_ 状态是一致的。
  • 需要注意的是,这种实现虽然正确,但由于 std::memory_order_seq_cst 的开销较大,通常会使用更轻量级的内存顺序(如 std::memory_order_acquire 和 std::memory_order_release)来优化性能。
示例 3:屏障同步

假设我们有两个线程,一个线程负责设置标志位,另一个线程负责检查标志位。我们希望确保设置标志位的线程在检查线程之前完成操作。

#include <atomic>
#include <iostream>
#include <thread>std::atomic<bool> ready{false};
int data = 0;void writer() {data = 100; // 写入数据ready.store(true, std::memory_order_seq_cst); // 设置标志位
}void reader() {while (!ready.load(std::memory_order_seq_cst)) { // 等待标志位std::this_thread::yield();}std::cout << "Data: " << data << std::endl; // 读取数据
}int main() {std::thread t1(writer);std::thread t2(reader);t1.join();t2.join();return 0;
}

说明

  • ready.store(true, std::memory_order_seq_cst) 和 ready.load(std::memory_order_seq_cst) 确保所有线程都能看到一致的 ready 状态。
  • 这样可以保证 writer 线程在 reader 线程之前完成操作。

5. 总结

  • std::memory_order_seq_cst 提供了最强的内存同步保证,适合需要全局一致性和顺序一致性的场景。
  • 在性能敏感的场景中,建议选择更轻量级的内存顺序(如 std::memory_order_acquire 和 std::memory_order_release)以优化性能。
  • 示例展示了 std::memory_order_seq_cst 在计数器、双检查锁和屏障同步中的应用。

std::memory_order_seq_cst 是 C++11 引入的内存模型中的一种内存顺序,代表了顺序一致性(Sequential Consistency)。在不同操作系统和 CPU 架构下,其实现方法可能有所不同,但它们都必须满足 C++ 标准对顺序一致性的要求。

1. Windows 操作系统

在 Windows 操作系统上,std::memory_order_seq_cst 的实现依赖于底层的 CPU 指令和内存模型。Windows 提供了多线程编程的支持,包括原子操作和内存屏障。

  • 原子操作:Windows 提供了 Interlocked* 函数来实现原子操作,例如 InterlockedExchange 和 InterlockedCompareExchange。这些函数在内部使用了 CPU 的锁前缀指令(如 lock 前缀)来保证原子性。

  • 内存屏障:Windows 提供了 MemoryBarrier 和 WriteBarrier 等函数来实现内存屏障,确保内存操作的顺序。

对于 std::memory_order_seq_cst,编译器会生成适当的原子操作和内存屏障指令,以确保顺序一致性。具体来说,在 x64 架构上,这通常涉及到使用 lock 前缀的指令和 mfence 指令来实现全内存屏障。

2. Linux 操作系统

在 Linux 操作系统上,std::memory_order_seq_cst 的实现同样依赖于底层的 CPU 指令和内存模型。Linux 提供了 POSIX 线程(pthreads)和原子操作的支持。

  • 原子操作:Linux 提供了 atomic_* 操作,例如 atomic_load 和 atomic_store,这些操作在内部使用了 CPU 的原子指令。

  • 内存屏障:Linux 提供了 memory_barrier 和 read_barrier_depends 等内存屏障函数,确保内存操作的顺序。

在 x64 架构上,编译器会生成 lock 前缀的指令来保证原子性,并使用 mfence 指令来实现全内存屏障,以满足 std::memory_order_seq_cst 的要求。

3. macOS 操作系统

在 macOS 操作系统上,std::memory_order_seq_cst 的实现也依赖于底层的 CPU 指令和内存模型。macOS 提供了 Grand Central Dispatch (GCD) 和原子操作的支持。

  • 原子操作:macOS 提供了 OSAtomic* 函数来实现原子操作,例如 OSAtomicCompareAndSwapInt

  • 内存屏障:macOS 提供了 OpaqueMemoryBarrier 和 LoadCommand 等内存屏障函数。

在 x64 架构上,编译器会生成相应的原子指令和内存屏障指令,以确保 std::memory_order_seq_cst 的顺序一致性。

4. X64 CPU 的支持

x64 架构的 CPU 提供了对多线程编程和内存模型的支持,包括原子操作和内存屏障指令。

  • 原子操作:x64 CPU 支持带 lock 前缀的指令,这些指令在总线上进行锁定,确保操作的原子性。例如,lock inc dword ptr [rsp] 会原子地增加内存地址 rsp 处的值。

  • 内存屏障:x64 CPU 提供了多种内存屏障指令,如 mfencelfence 和 sfence,分别用于全内存屏障、负载屏障和存储屏障。这些指令用于控制内存操作的顺序,确保某些操作在屏障之前或之后完成。

对于 std::memory_order_seq_cst,编译器会生成 lock 前缀的原子指令,并在需要时插入 mfence 指令来确保顺序一致性。

5. 总结

在 Windows、Linux 和 macOS 等操作系统上,std::memory_order_seq_cst 的实现都依赖于底层 CPU 的原子指令和内存屏障指令。编译器会根据目标架构生成相应的机器码,以确保满足 C++ 标准对顺序一致性的要求。在 x64 架构上,这通常涉及到使用 lock 前缀的指令和 mfence 指令来实现原子操作和内存屏障。

相关文章:

C++并发编程之内存顺序一致性

std::memory_order_seq_cst 是 C11 引入的内存模型中的一种内存顺序&#xff08;memory order&#xff09;&#xff0c;全称为 Sequential Consistency&#xff08;顺序一致性&#xff09;。它是 C 中最严格的内存顺序&#xff0c;提供了最强的同步保证。下面详细解释其含义、意…...

软件测试面试题整理

一、人格相关问题 1、自我介绍结构 姓名工作年限简单介绍上家公司的行业主要负责内容个人优势短期内的职业规划应聘该岗位的原因 2、对未来的发展方向怎么看 3、你对测试最大的兴趣在哪里&#xff1f;为什么&#xff1f; 二、技术相关问题 1、测试理论以及应用 1、给你一个…...

Java中如何实现线程安全的单例模式?

目录 1、懒汉式&#xff08;线程安全&#xff09; 2、饿汉式&#xff08;线程安全&#xff09; 3、双重校验锁&#xff08;线程安全&#xff09; 4、静态内部类&#xff08;推荐&#xff09; 5、枚举&#xff08;最佳方法&#xff09; 6、总结 在Java中&#xff0c;实现线…...

MYsql--------ubantu中安装mysql

在Ubuntu平台上下载、启动和关闭MySQL的方法如下&#xff1a; 下载安装MySQL 更新软件包列表&#xff1a;打开终端&#xff0c;输入以下命令&#xff0c;确保软件包列表是最新的。sudo apt update安装MySQL服务器&#xff1a;执行以下命令安装MySQL服务器。在安装过程中&…...

【Ubuntu】不能连上网络

1. ping路由器的IP地址 ping 192.168.1.1 如果ping不通的话&#xff0c;可能是网络故障导致的。需要重启配置ip地址。配置文件 sudo vi /etc/network/interface 2. ping 8.8.8.8 如果ping不通的话&#xff0c;可能是路由器不能链接往外网&#xff1b; 或者路由器显示了当…...

探索 AIGC 的基础知识:人工智能生成内容的全景视图

在数字化时代&#xff0c;人工智能生成内容&#xff08;AIGC&#xff09;正以前所未有的速度改变着我们的创作方式。本文将深入探讨 AIGC 的定义、构成要素、应用场景以及其带来的优势&#xff0c;帮助读者全面理解这一前沿技术。 1. AIGC 的定义与范围 人工智能生成内容&…...

使用java语言,自定义redistemplate

自定义 RedisTemplate 为了方便使用&#xff0c;你可以创建一个自定义的 RedisTemplate&#xff0c;并将其注入到服务中。 import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; import org.springframework.…...

React-Router 一站式攻略:从入门到精通,掌握路由搭建与权限管控

文章目录 一、前言二、安装使用 npm 安装&#xff08;推荐&#xff09;使用 yarn 安装 三、基础使用设置路由基础结构定义路由和组件关联直接在组件中定义路由定义单独一个路由表 创建导航链接 四、核心组件和功能BrowserRouter 和 HashRouterRoute 组件Link 组件Switch 组件 五…...

运动控制探针功能详细介绍(CODESYS+SV63N伺服)

汇川AM400PLC和禾川X3E伺服EtherCAT通信 汇川AM400PLC和禾川X3E伺服EtherCAT通信_汇川ethercat通信-CSDN博客文章浏览阅读1.2k次。本文详细介绍了如何使用汇川AM400PLC通过EtherCAT总线与禾川X3E伺服进行通信。包括XML硬件描述文件的下载与安装,EtherCAT总线的启用,从站添加…...

七种改进爬山算法的方法

一、爬山算法 爬山算法(Hill Climbing Algorithm)是一种启发式的基于局部最优解的搜索算法,用于在给定的搜索空间中寻找全局最优解或足够好的解。它属于局部搜索算法,通常用于解决优化问题,包括连续和离散问题。 爬山算法模拟了爬山的过程,从某个随机起始点开始,不断向更…...

【Cocos TypeScript 零基础 4.1】

目录 背景滚动 背景滚动 创建一个 空节点 背景丟进去 ( 复制一个,再丢一次都行) 新建TS脚本 并绑定到 空节点 上 再对TS脚本进行编辑 export class TS2bg extends Component {property (Node) // 通过属性面板去赋值bg1:Node nullproperty (Node) bg2:Node nullprope…...

gitlab高级功能之 CICD Steps

CICD Steps 1. 介绍2. 定义 Steps2.1 Inputs2.2 Outputs 3. Using steps3.1 Set environment variables3.2 Running steps locally 4. Scripts5. Actions5.1 已知的问题 6. 表达式7. 实操7.1 单个step7.2 多个step7.3 复用steps7.4 添加output到step7.5 使用远程step 1. 介绍 …...

全国城市经纬度--包括省会(直辖市)、地级市

全国城市未必齐全&#xff0c;谨慎使用。 一、全国城市csv数据 北京市 北京市 北京市 116.4 39.9 天津市 天津市 天津市 117.2 39.12 河北省 石家庄市 石家庄市 114.52 38.05 河北省 唐山市 唐山市 118.2 39.63 河北省 秦皇岛市 秦皇岛市 119.6 39.93 河北省 邯郸市 邯郸市 1…...

深入解析爬虫中的算法设计:提升效率与准确度

在网络爬虫&#xff08;Web Scraping&#xff09;中&#xff0c;设计高效、准确的算法是关键&#xff0c;尤其当面对大量数据或复杂的网站结构时&#xff0c;精心设计的爬虫算法能显著提高爬取速度并提升数据提取的准确性。本篇博客将详细讲解爬虫算法的设计与优化策略&#xf…...

java中统一异常处理,如何实现全局异常处理,@RestControllerAdvice 注解实现统一异常处理

文章目录 一、粗谈统一异常处理二、细谈统一异常处理&#xff1a;结合统一结果返回类为什么使用统一异常处理&#xff1f;怎么做&#xff1f;如何处理&#xff1f;代码实现&#xff1f; 一、粗谈统一异常处理 先看个案例&#xff1a; 1、写了一个接口&#xff1a; 实体类如下…...

vscode中调用deepseek实现AI辅助编程

来自 Python大数据分析 费弗里 1 简介 大家好我是费老师&#xff0c;最近国产大模型Deepseek v3新版本凭借其优秀的模型推理能力&#xff0c;讨论度非常之高&#x1f525;&#xff0c;且其官网提供的相关大模型API接口服务价格一直走的“价格屠夫”路线&#xff0c;性价比很高…...

设计模式七大原则

在软件开发的广袤领域中&#xff0c;设计模式如同熠熠生辉的灯塔&#xff0c;为开发者指引着通往高效、可维护、可扩展软件系统的方向。而设计模式背后的七大原则&#xff0c;更是这些灯塔的核心支撑&#xff0c;它们是软件开发过程中必须遵循的黄金法则&#xff0c;为我们构建…...

重庆市大数据局:基于可信数据空间的公共数据流通利用

在2024年可信数据空间论坛上&#xff0c;重庆市大数据局相关领导发表了题为&#xff1a;基于可信数据空间的公共数据流通利用的演讲&#xff0c;系统介绍了重庆公共数据流通方面的实践经验和案例。 篇幅限制&#xff0c;部分内容如下&#xff1a;...

高阶数据结构----布隆过滤器和位图

&#xff08;一&#xff09;位图 位图是用来存放某种状态的&#xff0c;因为一个bit上只能存0和1所以一般只有两种状态的情况下适合用位图&#xff0c;所以非常适合判断数据在或者不在&#xff0c;而且位图十分节省空间&#xff0c;很适合于海量数据&#xff0c;且容易存储&…...

SpringCloud源码分析-nacos与eureka

一、高版本为什么优先用nacos 如果用alibaba springcloud&#xff0c;那么就是阿里的技术体系。nacos属于阿里的原生技术栈&#xff0c;所以阿里更偏向于用nacos作为服务发现注册。 二、对比分析 Spring Cloud Alibaba 推荐使用 Nacos 作为服务发现和配置管理的首选组件&…...

多台DHCP服务器时的问题讨论

有两台DHCP服务器为主机提供DHCP服务会发生什么 在一个网络中&#xff0c;如果有两台设备同时连接到主机&#xff0c;并且它们都可以提供 DHCP 服务&#xff0c;这可能会引发以下问题&#xff1a; 1. IP 地址冲突 当两台设备都扮演 DHCP 服务器时&#xff0c;它们会分别为主…...

Golang的缓存一致性策略

Golang的缓存一致性策略 一致性哈希算法 在Golang中&#xff0c;缓存一致性策略通常使用一致性哈希算法来实现。一致性哈希算法能够有效地解决缓存节点的动态扩容、缩容时数据重新分布的问题&#xff0c;同时能够保证数据访问的均衡性。 一致性哈希算法的核心思想是将节点的哈希…...

Java-创建一个结合CompletableFuture和自定义功能的工具类

1.重试机制:当异步任务失败时自动重试。 2.超时重试:在指定时间内未完成的任务进行重试。 3.批量处理:将多个任务批量执行并收集结果。 4.日志记录:为每个异步任务添加日志记录,便于调试和监控。 5.自定义线程池:允许用户传入自定义的线程池配置。 import java.util…...

微机——计算机中的数制

目录 数制转换&#xff1a; 十进制数转为非十进制数&#xff1a; 二、八、十六进制数之间的转换&#xff1a; 数及字符的表示&#xff1a; 二进制数的加减运算&#xff1a; 无符号数的运算&#xff1a; 带符号数运算中的溢出问题&#xff1a; 计算机中常用的编码&#…...

DevSecOps自动化在安全关键型软件开发中的实践、Helix QAC Klocwork等SAST工具应用

DevSecOps自动化对于安全关键型软件开发至关重要。 那么&#xff0c;什么是DevSecOps自动化&#xff1f;具有哪些优势&#xff1f;为何助力安全关键型软件开发&#xff1f;让我们一起来深入了解~ 什么是DevSecOps自动化&#xff1f; DevSecOps自动化是指在软件开发生命周期的各…...

Linux下部署ElasticSearch集群

Elasticsearch7.17.8集群的搭建 节点host名称节点ip节点部署内容k8s-m192.168.40.142主节点 数据节点k8s-w1192.168.40.141主节点 数据节点k8s-w2192.168.40.140数据节点 一、准备安装环境 1.下载安装包 官网 www.elastic.co 下载所有版本地址 点击跳转 下载elasticsearch-7.…...

杰盛微 JSM4056 1000mA单节锂电池充电器芯片 ESOP8封装

JSM4056 1000mA单节锂电池充电器芯片 JSM4056是一款单节锂离子电池恒流/恒压线性充电器&#xff0c;简单的外部应用电路非常适合便携式设备应用&#xff0c;适合USB电源和适配器电源工作&#xff0c;内部采用防倒充电路&#xff0c;不需要外部隔离二极管。热反馈可对充电电流进…...

kubernetes学习-kubectl命令、探针(二)

一、在任意节点使用 kubectl # 在master节点获取节点信息 [rootk8s-master k8s]# kubectl get nodes NAME STATUS ROLES AGE VERSION k8s-master Ready control-plane,master 16h v1.23.6 k8s-node1 Ready <none> …...

多组学破解雪域雄鸡的高原缺氧适应机制

藏鸡‌是一种原产于中国青藏高原的鸡种&#xff0c;主要分布在海拔2200-4100米的河谷区和高山峡谷区。它们适应高海拔和寒冷的气候条件&#xff0c;能够在恶劣的环境中生存和繁殖‌。本研究主要关注高原藏鸡适应高原缺氧环境的机制&#xff0c;通过宏转录组测序和代谢组结果的联…...

Kubernetes Gateway API-3-TLS配置

1 简介 Gateway API 允许使用多种方式配置 TLS。本文档列出了各种TLS设置,并给出了如何有效使用它们的一般指南。 尽管本文档涵盖了 Gateway API 最常见的TLS配置形式,但某些实现也可能提供特定于实现的扩展,允许不同或更高级形式的TLS配置。除此文档外,值得阅读你所使用…...

C++ 中如何优雅地返回一个递归闭包函数?

在刷Leetcode时&#xff0c;我遇到了一道题目&#xff08;详见Leetcode 第426场周赛分析总结Q3&#xff09;&#xff0c;需要对两棵树建图&#xff0c;然后以每个节点作为根节点进行DFS遍历。一般的实现方法是将重复的逻辑封装起来&#xff0c;写两个函数&#xff0c;一个负责建…...

dockerignore文件怎么写

.dockerignore 文件是一个文本文件&#xff0c;告诉 Docker 在构建镜像时应该忽略哪些文件或目录。这个文件的作用类似于 .gitignore&#xff0c;用于排除不需要包含在 Docker 镜像中的文件或目录&#xff0c;以减少镜像的大小和提高构建速度。 .dockerignore 文件的格式 每行…...

利用 AI 高效生成思维导图的简单实用方法

#工作记录 适用于不支持直接生成思维导图的AI工具&#xff1b;适用于AI生成后不能再次编辑的思维导图。 在日常的学习、工作以及知识整理过程中&#xff0c;思维导图是一种非常实用的工具&#xff0c;能够帮助我们清晰地梳理思路、归纳要点。而借助 AI 的强大能力&#xff0c…...

SpringMVC(一)配置

目录 引入 第一章&#xff1a;Java web的发展历史 一、Model I和Model II 1.Model I开发模式 2.Model II开发模式 二. MVC模式 第二章&#xff1a;SpringMVC的入门案例 搭建SpringMVC的入门程序 1.创建新项目 2.等待加载导入坐标 3.处理xml文件和其他 导入tomcat 运…...

Vue3苦逼的学习之路

从一名测试转战到全栈是否可以自学做到&#xff0c;很多朋友肯定会说不可能&#xff0c;或就算转了也是个一般水平&#xff0c;我很认同&#xff0c;毕竟没有经过各种项目的摧残&#xff0c;但是还是得踏足一下这个领域。所以今天和大家分享vue3中的相关内容&#xff0c;大佬勿…...

github提交不上去,网络超时问题解决

问题出现的原因&#xff1a; DNS服务器数据不同步&#xff0c;github的服务器发送迁移&#xff0c;在本地缓存的ip地址现在无效了。 解决方案&#xff1a; 1&#xff09;点击这里&#xff0c;查询github.com最新的ip地址 2.0&#xff09;编辑linux系统地址缓存文件&#x…...

SAP物料主数据界面增加客制化字段、客制化页签的方式

文章目录 前言一、不增加页签&#xff0c;只增加客制化字段二、增加物料主数据页签 前言 【SAP系统MM模块研究】 #SAP #MM #物料 #客制化 #物料主数据 项目上难免会遇到客户要在物料主数据的界面上&#xff0c;增加新字段的需求。 实现方式有&#xff1a; &#xff08;1&…...

56.在 Vue 3 中使用 OpenLayers 通过 moveend 事件获取地图左上和右下的坐标信息

前言 在现代 Web 开发中&#xff0c;地图应用越来越成为重要的组成部分。OpenLayers 是一个功能强大的 JavaScript 地图库&#xff0c;它提供了丰富的地图交互和操作功能&#xff0c;而 Vue 3 是当前流行的前端框架之一。在本篇文章中&#xff0c;我们将介绍如何在 Vue 3 中集…...

DDoS攻击防御方案大全

1. 引言 随着互联网的迅猛发展&#xff0c;DDoS&#xff08;分布式拒绝服务&#xff09;攻击成为了网络安全领域中最常见且危害严重的攻击方式之一。DDoS攻击通过向目标网络或服务发送大量流量&#xff0c;导致服务器过载&#xff0c;最终使其无法响应合法用户的请求。本文将深…...

OLED的显示

一、I2C I2C时序&#xff1a;时钟线SCL高电平下&#xff1a;SDA由高变低代表启动信号&#xff0c;开始发送数据&#xff1b;SCL高电平时&#xff0c;数据稳定&#xff0c;数据可以被读走&#xff0c;开始进行读操作&#xff0c;SCL低电平时&#xff0c;数据发生改变&#xff1…...

BP神经网络的反向传播算法

BP神经网络&#xff08;Backpropagation Neural Network&#xff09;是一种常用的多层前馈神经网络&#xff0c;通过反向传播算法进行训练。反向传播算法的核心思想是通过计算损失函数对每个权重的偏导数&#xff0c;从而调整权重&#xff0c;使得网络的预测输出与真实输出之间…...

CS·GO搬砖流程详细版

说简单点&#xff0c;就是Steam买了然后BUFF上卖&#xff0c;或许大家都知道这点&#xff0c;但就是一些操作和细节问题没那么明白。我相信&#xff0c;你看完这篇文章以后&#xff0c;至少会有新的认知。 好吧&#xff0c;废话少说&#xff0c;直接上实操&#xff01; 首先准…...

ElasticSearch系列(一)

一.了解ES、倒排索引、es的一些概念、安装es、kibana 二.DSL&#xff1b;索引库操作 三.Java RestClient&#xff1a;索引库操作 一、了解ES、倒排索引、es的一些概念、安装es、kibana kibana、logstash、beats Elasticserach 存储&#xff0c;计算 &#xff0c;搜索数据 –…...

vue字符串的数字比较大小有问题

问题代码 this.money 9999 //支付金额this.balance 678 //余额if (this.money > this.balance) {this.$message(余额不足&#xff0c;请更换支付方式);}问题原因 this.money和 this.balance不是数值类型而是字符串类型 解决方案 使用parseFloat将变量转换成统一的类…...

Java:缓存:LinkedHashMap实现Lru

文章目录 Lru源码分析 ​​​​​​​​​​​​​​LinkedHashMap维护一个LinkedHashMapEntry<K,V>的双向链表对LinkedHashMap的增删查操作,也会对链表进行相同的操作并改变链表的链接顺序小结使用方法​​​​​​​​​​​​​​应用总结Lru Least Recently Used,…...

Jetpack Compose 学习笔记(一)—— 快速上手

本篇主要是对 Jetpack Compose 有一个宏观上的了解。 1、Jetpack Compose 是什么与优势 Jetpack Compose 是用于构建原生 Android 界面的新工具包。它使用更少的代码、强大的工具和直观的 Kotlin API&#xff0c;可以帮助您简化并加快 Android 界面开发。 Compose 的优势&am…...

【大模型】7 天 AI 大模型学习

7 天 AI 大模型学习 Day 2 今天是 7 天AI 大模型学习的第二天 &#x1f604;&#xff0c;今天我将会学习 Transformer 、Encoder-based and Decoder-Based LLMs 等 。如果有感兴趣的&#xff0c;就和我一起开始吧 &#xff5e; 课程链接 &#xff1a;2025年快速吃透AI大模型&am…...

JVM对象创建过程

1 类加载检查 jvm通过new指令开始创建对象jvm执行new指令时&#xff0c;首先通过指令参数从常量池中取到需要创建的类名检查该类是否被加载&#xff0c;解析&#xff0c;和初始化过如果没有&#xff0c;则执行类的加载过程new指令对应到java语言具体的操作为 new 关键字创建对象…...

OSPF - SPF算法简述

SPF全称最短路径树算法&#xff0c;相信学过数据结构朋友应该看起来很熟悉  在一个区域内的路由器都会产生描述自己网络连接信息的LSA&#xff0c;包括两种信息&#xff0c;有路由信息和拓扑信息&#xff0c;简单的来说拓扑信息就是我连着谁&#xff0c;路由信息就是链路的地址…...

[实用指南]如何将视频从iPhone传输到iPad

概括 将视频从 iPhone 传输到 iPad 时遇到问题&#xff1f;您可能知道一种方法&#xff0c;但不知道如何操作。此外&#xff0c;您要传输的视频越大&#xff0c;完成任务就越困难。那么如何将视频从 iPhone 传输到 iPad&#xff0c;特别是当您需要发送大视频文件时&#xff1f…...