进程通信详解
进程间通信(IPC)详解:原理、方式与使用场景全解析
摘要
进程间通信(IPC)是操作系统中用于实现多个独立进程之间数据交换和资源协作的重要机制。本文系统地讲解了 IPC 的基本概念、设计目标和系统实现原理,并深入解析了八种常见的 IPC 方式,包括管道、命名管道、消息队列、共享内存、信号、信号量、套接字和内存映射文件。每种方式都从底层原理、内核机制、特性和典型应用场景展开说明,并通过对比表格总结它们的适用条件,帮助开发者在实际项目中正确选择合适的通信机制。
💡一、什么是“进程”?
先从“进程”说起。
进程是操作系统中运行的一个程序实例。你打开了一个浏览器,它就是一个进程;你打开了一个播放器,它也是一个进程。
每个进程是 独立的“沙盒”,拥有自己独立的:
- 内存空间(变量、函数等)
- 文件描述符
- 系统资源(比如线程)
也就是说,一个进程不能直接访问另一个进程的内存空间。
🤝二、为什么需要进程通信?
当多个进程需要协同工作,例如:
- 进程 A:接收用户输入
- 进程 B:处理逻辑并返回结果
这两个进程虽然各自运作,但你希望它们 协作起来完成一件事。例如:
- 进程 A 把用户输入“传”给进程 B
- 进程 B 把结果“返回”给进程 A
问题来了:它们是彼此隔离的,怎么“传东西”?怎么交换数据或同步状态呢?
这就要用到 进程通信(IPC, Inter-Process Communication)。
🎯三、进程通信的目标
进程通信要解决两个核心问题:
- 数据交换:一个进程把信息传给另一个进程
- 资源同步:多个进程访问共享资源(比如共享内存)时要避免“抢资源”,保持有序访问
比如:
- A 进程写一个消息,B 进程读这个消息
- 多个进程往一个日志文件里写日志,要按顺序写,不能写乱了
它们就需要交换数据或同步状态。这时候就需要进程间通信(IPC, Inter-Process Communication)机制。
🧠IPC 的两大目标:
- 数据交换:一个进程把信息传给另一个进程
- 资源同步:多个进程协作访问共享资源,避免冲突
🧬四、进程通信的底层原理
进程通信的本质,就是借助 操作系统提供的中介机制,让不同的进程能“看见彼此”,交换数据。
🧩1. 操作系统内核中介机制
操作系统提供内核缓冲区供多个进程写入和读取数据,例如管道、消息队列、socket 等。
比如:
- 管道(Pipe)
- 消息队列(Message Queue)
- 套接字(Socket)
这类方式通过 内核维护的缓冲区 进行通信:
- A 进程写数据到缓冲区
- B 进程从缓冲区读数据
📦 就像两个人用一个中间的信箱来交换信件。
🧷2. 共享内存机制
多个进程映射同一块物理内存,实现高速通信,需要配合同步机制避免抢占。
比如:
- 共享内存段(Shared Memory)
这类方式让两个进程都能访问一块内存区域:
- A 写入内存
- B 读出内存
🚪 这就像两个房间的人打开了同一扇窗户,共用一张桌子。
但问题来了:可能会“抢桌子”!
所以要配合 信号量、互斥锁 控制访问顺序。
🔔3. 通知型机制
信号、事件等方式用于进程状态通知,不直接传数据。
这类方式用于通知:
- “我执行完了”
- “你可以开始了”
- “某个资源空闲了”
🔔 类似敲钟通知:“现在可以轮到你了!”
📦五、常见的进程通信方式对比
方式 | 是否跨平台 | 简介 | 特点 | 难度 |
---|---|---|---|---|
管道(Pipe) | 否 | 基于内核缓冲区的数据流 | 父子进程通信、单向 | ⭐ |
命名管道(Named Pipe) | 是 | 通过文件系统命名 | 可跨进程使用 | ⭐⭐ |
消息队列(Message Queue) | 否 | 基于内核消息链表 | 支持结构化、可靠性高 | ⭐⭐⭐ |
共享内存(Shared Memory) | 否 | 多进程共享一块内存区域 | 速度最快,需同步机制 | ⭐⭐⭐⭐ |
信号(Signal) | 否 | 异步通知事件 | 不传数据,仅通知 | ⭐ |
信号量(Semaphore) | 否 | 控制共享资源访问 | 用于同步而非传输 | ⭐⭐ |
套接字(Socket) | 是 | 本地和网络通信 | 跨平台、灵活通用 | ⭐⭐⭐⭐ |
内存映射文件(Memory-Mapped File) | 是 | 文件映射为内存供多进程访问 | 可跨平台、适合持久共享 | ⭐⭐⭐ |
🛠️六、一个形象的类比:办公室通信
想象你在一个办公室,每个人代表一个进程。你们需要沟通协作时,可以用以下“通信方式”:
通信方式 | 类比 | 特点 |
---|---|---|
管道 | 用纸条递给旁边的同事 | 快速但范围小 |
命名管道 | 把纸条放进文件柜里,谁都能拿 | 范围更大 |
消息队列 | 一个专门的消息收发室 | 有序处理,多人协作 |
共享内存 | 在墙上贴一块白板,大家都能写 | 要守规矩,不然乱成一团 |
Socket | 打电话 | 无论对方在哪都能联系 |
📚七、每种通信方式详解
🧵1. 匿名管道(Anonymous Pipe)
📚原理
- 操作系统通过内核提供一段缓冲区(管道缓冲区)
- 父进程创建
pipe(fd)
后得到两个文件描述符:fd[0]
读端fd[1]
写端
- 常用于 父子进程通信,因为
fork()
后子进程可以继承父进程的管道
🧠内核视角
- 管道缓冲区在 内核空间
- 数据由写端进入,读端取出(单向通信)
- 写入时内核缓存,读取后自动清除
✅特点
- 简单、高效
- 只能用于 相关进程(如父子)
🧰典型场景
- Shell 中命令管道:
ls | grep txt
- 后台任务数据传输
📦2. 命名管道(Named Pipe / FIFO)
📚原理
- 管道存在于文件系统中的一个“特殊文件”
- 通过
mkfifo()
创建 - 不限于父子进程,任何进程都能打开这个“管道文件”通信
🧠内核视角
- 使用 VFS 虚拟文件系统接口访问内核中的 FIFO 对象
- 管道本质仍然是内核缓存区
✅特点
- 跨进程、跨用户通信
- 只适合 同一台主机
🧰典型场景
- 客户端和守护进程之间本地通信
- 轻量替代 socket 的本地单向消息机制
💬3. 消息队列(Message Queue)
📚原理
- 操作系统内核维护一组队列
- 每个消息有一个 类型标识符,可以按类型发送或读取
- 使用
msgsnd()
和msgrcv()
系统调用实现收发
🧠内核视角
- 每个队列以“链表”形式存储多个消息结构体
- 内核负责排队和消息分发
- 消息格式可自定义结构体,适合结构化通信
✅特点
- 支持 有序、可靠 的消息通信
- 支持 同步和异步
- 通信双方无需共享内存,数据安全性好
🧰典型场景
- 多个进程轮询任务或消息调度系统
- 进程池任务分发
🧠4. 共享内存(Shared Memory)
📚 原理
- 操作系统允许多个进程把同一个物理内存页映射到各自的虚拟地址空间
- 使用
shmget()
、shmat()
等函数分配和附加共享内存段
🧠 内核视角
- 内核维护共享内存的权限、映射计数等
- 本质上是 多个进程看到“同一片内存”
⚠️ 需要注意
- 是 最快的通信方式,但需配合同步机制(如互斥锁、信号量)避免竞态条件
✅ 特点
- 高性能、大数据传输
- 需要协作进行同步(数据一致性要靠自己维护)
🧰 典型场景
- 图像处理进程共享图像帧
- 高频交易系统中多个策略进程共享行情数据
📯5. 信号(Signal)
📚原理
- 操作系统支持“软中断”,即异步通知某个进程发生了某种事件
- 常见如
SIGINT
(Ctrl+C)、SIGTERM
、SIGUSR1
🧠内核视角
- 内核通过信号编号维护一张信号表
- 进程可以注册处理函数(Signal Handler)
✅特点
- 适合通知型通信
- 不传输数据
- 响应速度快
🧰典型场景
- 通知另一个进程“你可以开始干活了”
- 通知子进程退出、重启、重新加载配置等
🧮6. 信号量(Semaphore)
📚原理
- 信号量是一个 用于同步的计数器
- 值为正:表示可用资源数量
- 值为 0:表示等待资源
- 操作:P(等待)、V(释放)
🧠内核视角
- 信号量由内核维护,有原子性保证
- 与共享内存配合使用非常常见
✅特点
- 用于进程间资源访问控制
- 不用于传递数据
🧰典型场景
- 控制对共享内存、文件等资源的并发访问
- 多生产者多消费者模型
🌐7. 套接字(Socket)
📚原理
- Socket 本质是一个文件描述符,通过
send()
、recv()
传输数据 - 支持:
- 本地进程通信(Unix Domain Socket)
- 网络通信(TCP/UDP)
🧠内核视角
- socket 在内核中有 socket 缓冲区、协议栈(TCP/UDP/IP)
- socket 是一种更通用、更强大的通信手段
✅特点
可实现 远程进程通信
可双向通信
适合复杂或分布式架构
🧰典型场景
- Web 服务器和浏览器通信
- 本地服务(比如
X Window Server
)
🧾8. 内存映射文件(Memory-Mapped File)
📚原理
- 把磁盘上的文件映射到进程地址空间中
- 两个或多个进程映射同一个文件时,能看到彼此写入的数据
🧠内核视角
- 使用内核的页缓存机制把文件页映射到虚拟地址
- 数据写入触发脏页更新,最终刷新回文件
✅特点
- 类似共享内存,但底层是文件系统
- 跨平台,适合 长期存储
🧰典型场景
- 浏览器缓存共享(多个进程读写历史文件)
- 多个进程处理同一个数据库文件
📊八、对比与选择建议
IPC方式 | 是否传数据 | 是否跨平台 | 性能 | 适合用途 |
---|---|---|---|---|
管道 | ✅ | 否 | 中 | 父子进程间简单的数据传递(一次性命令/结果) |
命名管道 | ✅ | 是 | 中 | 同一主机不同进程间通信,如客户端-服务端模型 |
消息队列 | ✅ | 否 | 中 | 多对多结构化消息交互,任务/事件驱动模型 |
共享内存 | ✅ | 否 | ✅最快 | 大量数据高速交换,如图像处理、缓存共享 |
信号 | ❌ | 部分 | 快 | 简单事件通知,如定时器、终止、重新加载指令 |
信号量 | ❌ | 否 | 高 | 多进程同步或互斥控制(通常配合共享内存使用) |
套接字 | ✅ | 是 | 中等 | 同机或远程通信,跨平台跨网络,如HTTP、RPC等 |
内存映射文件 | ✅ | 是 | 高 | 文件型数据共享、持久化交换、跨语言通信等 |
🧾九、总结
- IPC 是解决进程协作问题的核心机制
- 每种方式都有其底层机制与适配场景
- 通信方式选择应基于:数据量、实时性、通信关系、是否跨平台 等因素
相关文章:
进程通信详解
进程间通信(IPC)详解:原理、方式与使用场景全解析 摘要 进程间通信(IPC)是操作系统中用于实现多个独立进程之间数据交换和资源协作的重要机制。本文系统地讲解了 IPC 的基本概念、设计目标和系统实现原理,…...
《What Are Step-Level Reward Models Rewarding?》全文翻译
《What Are Step-Level Reward Models Rewarding?Counterintuitive Findings from MCTS-Boosted Mathematical Reasoning》 Step-Level奖励模型到底奖励了什么?来自基于MCTS提升的数学推理的反直觉发现 摘要 Step-level奖励模型(SRMs)通过…...
windows使用docker-desktop安装milvus和可视化工具attu
这里写目录标题 docker-desktop安装docker安装milvusdocker安装milvus可视化工具attu注意点 docker-desktop安装 参考:Windows Docker 安装 docker安装milvus 参考:添加链接描述在 Docker 中运行 Milvus(Windows) docker安装m…...
如何通过原型链实现方法的“重写”(Override)?
在 JavaScript 中,通过原型链实现方法的 “重写”(Override) 的核心思路是:在子类(或子对象)的原型链上定义同名方法,覆盖父类(或父对象)的方法。以下是具体实现步骤和代…...
PyTorch - Tensor 学习笔记
上层链接:PyTorch 学习笔记-CSDN博客 Tensor 初始化Tensor import torch import numpy as np# 1、直接从数据创建张量。数据类型是自动推断的 data [[1, 2],[3, 4]] x_data torch.tensor(data)torch.tensor([[2, 1, 4, 3], [1, 2, 3, 4], [4, 3, 2, 1]])输出&am…...
《协议栈的骨架:从Web请求到比特流——详解四层架构的可靠传输与流量控制》
前言 本篇博客将详细介绍网络原理(细~~~) 💖 个人主页:熬夜写代码的小蔡 🖥 文章专栏 若有问题 评论区见 🎉欢迎大家点赞👍收藏⭐文章 一.应用层 这里的应用层只是个开头&a…...
软考 系统架构设计师系列知识点 —— 设计模式之创建者模式
本文内容参考: 软考 系统架构设计师系列知识点之设计模式(2)_系统架构设计师中考设计模式吗-CSDN博客 创建者模式_百度百科 建造者模式_百度百科 https://zhuanlan.zhihu.com/p/551870461 特此致谢! Builder Pattern…...
oracle判断同表同条件查出两条数据,根据长短判断差异
目标:同一个物料,账套不同,排查同料号有差异的规格名称 在Oracle数据库中,如果你想查询同一张表中两条数据某个字段的长度不同的情况,你可以使用JOIN语句或者窗口函数(如ROW_NUMBER()、RANK()、DENSE_RANK…...
咋用fliki的AI生成各类视频?AI生成视频教程
最近想制作视频,多方考查了决定用fliki,于是订阅了一年试试,这个AI生成的视频效果来看真是不错,感兴趣的自己官网注册个账号体验一下就知道了。 fliki官网 Fliki生成视频教程 创建账户并登录 首先,访问fliki官网并注…...
【STM32-代码】
STM32-代码 ■ printf() 输出到uart1■■■ ■ printf() 输出到uart1 static UART_HandleTypeDef * g_HDebugUART &huart1;int fputc(int c, FILE *f) {(void)f;HAL_UART_Transmit(g_HDebugUART, (const uint8_t *)&c, 1, DEBUG_UART_TIMEOUT);return c; }int fgetc…...
用cursor三个小时复刻高德地图的足迹地图
用cursor三个小时复刻了高德地图的足迹地图,当然,是“低配”版的。 1、首先要初始化,提出一个需求,让它自由发挥 运行之后发现它报错了,原因出在这行代码,“https://cdn.jsdelivr.net/npm/echarts5,4.3/…...
Git分支管理与工作流实践
Git分支管理与工作流实践 一、Git分支规范与核心原则 主分支(master/main) 核心作用:存储生产环境代码,永远保持稳定且可直接发布。禁止直接在此分支开发。操作规范:仅通过合并release或hotfix分支更新,合…...
python面试总结
目录 Python基础 1、python及其特点 2、动态类型和静态类型? 3、变量命名规则是什么? 4、基本数据类型有哪些? 5、Python 中字典? 6、集合set是什么?有什么特点? 7、python的字符串格式化 函数 1…...
基于骨骼识别的危险动作报警系统设计与实现
基于骨骼识别的危险动作报警系统设计与实现 基于骨骼识别的危险动作报警分析系统 【包含内容】 【一】项目提供完整源代码及详细注释 【二】系统设计思路与实现说明 【三】基于骨骼识别算法的实时危险行为预警方案 【技术栈】 ①:系统环境:Windows 10…...
HarmonyOS 5.0应用开发——五子棋游戏(鸿蒙版)开发
【高心星出品】 文章目录 五子棋游戏(鸿蒙版)开发运行效果开发步骤项目结构核心代码棋盘组件:游戏逻辑处理:主页面: 五子棋游戏(鸿蒙版)开发 五子棋是一款传统的两人策略型棋类游戏࿰…...
避坑,app 播放器media:MediaElement paly报错
System.Runtime.InteropServices.COMException HResult=0x8001010E Message= Source=WinRT.Runtime StackTrace: 在 WinRT.ExceptionHelpers.<ThrowExceptionForHR>g__Throw|38_0(Int32 hr) 在 ABI.Microsoft.UI.Xaml.Controls.IMediaPlayerElementMethods.get_MediaPlay…...
STM32单片机入门学习——第38节: [11-3] 软件SPI读写W25Q64
写这个文章是用来学习的,记录一下我的学习过程。希望我能一直坚持下去,我只是一个小白,只是想好好学习,我知道这会很难,但我还是想去做! 本文写于:2025.04.16 STM32开发板学习——第一节: [1-1]课程简介 前言开发板说明引用解答和…...
使用阿里云创建公司官网(使用wordpress)
安装 LNMP 不通的lnmp版本 https://lnmp.org/download.html wget http://soft.vpser.net/lnmp/lnmp2.1.tar.gz -cO lnmp2.1.tar.gztar zxf lnmp2.1.tar.gz && cd lnmp2.1 && ./install.sh lnmp数据库选5.7 选好数据库,会让你设置数据库 root 用户…...
Python程序结构深度解析:顺序结构与对象布尔值的底层逻辑与应用
一、程序结构的三大基石 在计算机科学领域,任何复杂的算法都可以分解为顺序结构、选择结构和循环结构这三种基本结构的组合。这种结构化编程思想由计算机科学家Bhm和Jacopini在1966年首次提出,至今仍是现代编程语言设计的核心原则。 1.1 顺序结构的本质…...
【系统搭建】Ubuntu系统两节点间SSH免密配置
SSH免密配置是MPI分布式、DPDK通信等集群节点间通信的基础配置 1. 安装SSH服务端(所有节点执行) Ubuntu 默认只安装 SSH 客户端(openssh-client),未安装服务端(openssh-server),需要手动安装并…...
美信监控易:揭秘高效数据采集和数据分析双引擎
在当今复杂多变的运维环境中,一款强大的运维管理软件对于保障企业的IT系统稳定运行至关重要。北京美信时代的美信监控易运维管理软件,凭借其卓越的数据分析双引擎,成为了众多运维团队的首选。 首先,美信监控易的数据采集引擎展现出…...
基于STM32+FPGA的地震数据采集器软件设计,支持RK3568+FPGA平台
0 引言 地震观测是地球物理观测的重点,是地震学和 地球物理学发展的基础 [1] 。地震数据采集器主要功 能是将地震计采集的地震波模拟信号转换为数字信 号并进行记录或传输 [2] ,为地震学提供大量的基础 数据。本文将介绍基FPGAARM的地震数据采集器软…...
NO.95十六届蓝桥杯备战|图论基础-单源最短路|负环|BF判断负环|SPFA判断负环|邮递员送信|采购特价产品|拉近距离|最短路计数(C++)
P3385 【模板】负环 - 洛谷 如果图中存在负环,那么有可能不存在最短路。 BF算法判断负环 执⾏n轮松弛操作,如果第n轮还存在松弛操作,那么就有负环。 #include <bits/stdc.h> using namespace std;const int N 2e3 10, M 3e3 1…...
Linux 网络管理深度指南:从基础到高阶的网卡、端口与路由实战
一、网卡管理:构建网络连接的基石 1.1 现代网络工具链解析 在当代Linux系统中,iproute2套件已全面取代传统的net-tools,其优势体现在: 推荐组合命令: ip -c addr show | grep "inet " # 彩色显示有效IP…...
《重构全球贸易体系用户指南》解读
文章目录 背景核心矛盾与理论框架美元的“特里芬难题”核心矛盾目标理论框架 政策工具箱的协同运作机制关税体系的精准打击汇率政策的混合干预安全工具的复合运用 实施路径与全球秩序重构阶段性目标 风险传导与反制效应内部失衡加剧外部反制升级系统性风险 范式突破与理论再思考…...
stateflow中的函数
最近开始使用STATEFLOW,感觉功能比较强大,在嵌入式的应用中应该缺少不了,先将用到的仔细总结一下。还有一点,积极拥抱ai,学会使用AI的强大功能来学习。 在 Stateflow 中,不同类型的函数和状态适用于不同的建模需求。以下是 图形函数(Graphical Function)、Simulink 函…...
41.[前端开发-JavaScript高级]Day06-原型关系图-ES6类的使用-ES6转ES5
JavaScript ES6实现继承 1 原型继承关系图 原型继承关系 创建对象的内存表现 2 class方式定义类 认识class定义类 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><meta http-equiv"X-UA-Compatible&qu…...
Flutter学习四:Flutter开发基础(一)Widget
Widget 简介 0 引言 本文是对 Flutter Widget 相关知识的学习和总结。 1 Widget 概念 1.1 Widget 基础 Widget 字面意思:控件、组件、部件、微件、插件、小工具widget 的功能是"描述一个UI元素的配置信息",所谓的配置信息就是 Widget 接收…...
Dify智能体平台源码二次开发笔记(6) - 优化知识库pdf文档的识别
目录 前言 新增PdfNewExtractor类 替换ExtractProcessor类 最终结果 前言 dify的1.1.3版本知识库pdf解析实现使用pypdfium2提取文本,主要存在以下问题: 1. 文本提取能力有限,对表格和图片支持不足 2. 缺乏专门的中文处理优化 3. 没有文档结…...
【LaTeX】公式图表进阶操作
公式 解决不认识的符号 查资料:1)知道符号样子;2)知道符号含义 放大版括号 用来括住存在分式的式子,或者用来括住内部由有很多括号的式子。用法是在左右括号[]分别加上\left和\right \[ J_r\dfrac{i \hbar}{2m} \l…...
第二阶段:数据结构与函数
模块4:常用数据结构 (Organizing Lots of Data) 在前面的模块中,我们学习了如何使用变量来存储单个数据,比如一个数字、一个名字或一个布尔值。但很多时候,我们需要处理一组相关的数据,比如班级里所有学生的名字、一本…...
matlab中simulink的快捷使用方法
连接系统模块还有如下更有效的方式:单击起始模块。 按下 Ctrl键,并单击目标块。 图示为已经连接好的系统模块 旋转模块:选中模块后按图示点击即可...
Redux部分
在src文件夹下 的store文件夹下创建modules/user.js和index.js module/ user.js // 存储用户相关const { createSlice } require("reduxjs/toolkit");const userStore createSlice({name:"user",// 数据状态initialState:{token:},// 同步修改方法red…...
基于STM32F103C8T6的温湿度检测装置
一、系统方案设计 1、系统功能分析 本项目设计的是一款基于STM32F103C8T6的温室大棚检测系统低配版。由 STM32F103C8T6最小系统板,OLED显示屏,DHT11温湿度检测传感器,光敏电阻传感器组成, 可以实现如下功能: 使用D…...
设计模式 - 单例模式
一个类不管创建多少次对象,永远只能得到该类型一个对象的实力 常用到的,比如日志模块,数据库模块 饿汉式单例模式:还没有获取实例对象,实例对象就已经产生了 懒汉式单例模式:唯一的实例对象,…...
Linux驱动开发1 - Platform设备
背景 所有驱动开发都是基于全志T507(Android 10)进行开发,用于记录驱动开发过程。 简介 什么是platform驱动自己上网搜索了解。 在driver/linux/platform_device.h中定义了platform_driver结构体。 struct platform_driver {int (*probe…...
力扣-hot100(盛最多水的容器)
11. 盛最多水的容器 中等 给定一个长度为 n 的整数数组 height 。有 n 条垂线,第 i 条线的两个端点是 (i, 0) 和 (i, height[i]) 。 找出其中的两条线,使得它们与 x 轴共同构成的容器可以容纳最多的水。 返回容器可以储存的最大水量。 说明…...
使用 PyTorch 构建 UNet 图像去噪模型:从数据加载到模型训练的完整流程
图像去噪是计算机视觉中的一个基础问题,在医学图像、遥感、夜间视觉等领域有广泛应用。本文将手把手带你用 PyTorch 构建一个 UNet 架构的图像去噪模型,包括数据预处理、网络搭建、PSNR 评估与模型保存的完整流程。 本项目已支持将数据增强版本保存为独立…...
从信号处理角度理解图像处理的滤波函数
目录 1、预备知识 1.1 什么是LTI系统? 1.1.1 首先来看什么是线性系统,前提我们要了解什么是齐次性和叠加性。...
集合框架--List集合详解
List集合 List 接口直接继承 Collection 接口,它定义为可以存储重复元素的集合,并且元素按照插入顺序有序排列,且可以通过索引访问指定位置的元素。常见的实现有:ArrayList、LinkedList。 Arraylist:有序、可重复、有索引 Linke…...
需求分析---软件架构师武器库中的天眼系统
在软件架构中,需求分析决定了系统的核心设计方向。 然而,现实中的需求往往存在以下问题: 需求被二次加工:产品经理或业务方可能直接提供“解决方案”(如“我们需要一个聊天功能”),而非原始需…...
Spring Cloud Gateway 的执行链路详解
Spring Cloud Gateway 的执行链路详解 🎯 核心目标 明确 Spring Cloud Gateway 的请求处理全过程(从接收到请求 → 到转发 → 到返回响应),方便你在合适的生命周期节点插入你的逻辑。 🧱 核心执行链路图(执…...
Python----机器学习(基于PyTorch框架的逻辑回归)
逻辑回归是一种广泛使用的统计学习方法,主要用于处理二分类问题。它基于线性回归模型,通过Sigmoid函数将输出映射到[0, 1]范围内,表示实例属于正类别的概率。尽管逻辑回归适用于二分类任务,但在多分类问题中常使用Softmax函数&…...
工业数据治理范式革新:时序数据库 TDengine虚拟表技术解析
小T导读:在工业数字化过程中,数据如何从设备采集顺利“爬坡”到上层应用,一直是个难题。传统“单列模型”虽贴合设备协议,却让上层分析举步维艰。TDengine 用一种更聪明的方法打通了这条数据通路:不强求建模、不手动转…...
Linux的应用领域,Linux的介绍,VirtualBox和Ubuntu的安装,VMware的安装和打开虚拟机CentOS
目录 Linux的应用领域 Linux的介绍 Linux的介绍 Linux发行版 Unix和Linux的渊源 虚拟机和Linux的安装 VirtualBox和Ubuntu的安装 安装VirtualBox 安装Ubuntu 下载Ubuntu操作系统的镜像文件 创建虚拟机 虚拟机设置 启动虚拟机,安装Ubuntu系统 Ubuntu基…...
使用 Java 8 Stream实现List重复数据判断
import java.util.*; import java.util.stream.Collectors;public class DeduplicateStreamExample {static class ArchiveItem {// 字段定义与Getter/Setter省略(需根据实际补充)private String mATNR;private String lIFNR;private String suppSpecMod…...
GDAL:地理数据的万能瑞士军刀
目录 1. 什么是GDAL?2. 为什么需要GDAL?3. GDAL的主要功能3.1. 数据转换3.2. 数据裁剪和处理3.3. 读取和写入多种格式 4. 实际应用场景4.1 环境监测4.2 城市规划4.3 导航系统 5. 技术原理简单解释6. 如何使用GDAL?6.1 简单命令示例 7. 学习建…...
每日文献(十三)——Part two
今天从第三章节:“实现细节”开始介绍。 目录 三、实现细节 四、实验 五、总结贡献 六、致谢 三、实现细节 我们在多尺度图像上训练和测试区域建议和目标检测网络。这是在KITTI目标检测基准[13]上基于CNN的目标检测的趋势。例如,在[16]中ÿ…...
ArrayList 和 LinkedList 区别
ArrayList 和 LinkedList 是 Java 集合框架中两种常用的列表实现,它们在底层数据结构、性能特点和适用场景上有显著的区别。以下是它们的详细对比以及 ArrayList 的扩容机制。 1. ArrayList 和 LinkedList 的底层区别 (1) 底层数据结构 ArrayList: 基于…...
【iOS】UITableView性能优化
UITableView性能优化 前言优化从何入手优化的本质 CPU层级优化1. Cell的复用2. 尽量少定义Cell,善于使用hidden控制显示视图3. 提前计算并缓存高度UITableView的代理方法执行顺序Cell高度缓存高度数组 4. 异步绘制5. 滑动时按需加载6. 使用异步加载图片,…...