news 2026/5/26 2:06:12

进程间通信--共享内存

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
进程间通信--共享内存

共享内存的基本原理

1. 核心步骤

要在 Linux 中使用 System V 共享内存,通常遵循以下“四步走”:

  1. 创建/获取 (Create/Get):向内核申请一块共享内存,就像malloc一样,但这是内核管理的。
    • 系统调用:shmget
  1. 关联 (Attach):把这块物理内存“挂接”到当前进程的虚拟地址空间(堆栈之间)。挂接后,这就变成了你进程内的一个指针。
    • 系统调用:shmat(Shared Memory Attach)
  1. 使用 (Use):像使用普通数组或指针一样读写数据。
  2. 去关联 (Detach):用完了,把这块内存从页表中去掉(断开联系)。
    • 系统调用:shmdt(Shared Memory Detach)
  1. 删除 (Control/Remove):如果所有进程都不用了,需要请求内核释放这块物理内存。
    • 系统调用:shmctl
2. 这里的“坑”:生命周期

这是一个极其重要的概念,也是和管道最大的区别。

  • 管道:进程退出了,管道就自动销毁了(匿名管道),或者没人用时虽然文件在但数据清空了(命名管道)。
  • 共享内存随内核 (Kernel Persistence)
    • 如果你创建了共享内存,进程 A 退出了,进程 B 也退出了,但这块内存依然存在于内核中
    • 除非你显式调用代码删除它,或者重启操作系统,否则它会一直占用物理内存。
    • 后果:调试代码时如果程序崩溃没来得及清理,你会发现内存泄漏,下次启动程序可能报错“File exists”。

系统调用详解

为了写代码,我们需要先认识这几个核心函数的参数。这部分比mkfifo复杂,涉及到一个新的概念:Key

1.ftok—— 生成唯一标识符

怎么让两个无关的进程(Server 和 Client)找到同一个共享内存呢?

  • 命名管道:靠文件路径(唯一)。
  • 共享内存:靠Key 值(唯一)。

我们需要一个算法,把一个文件路径和一个项目 ID 转换成一个唯一的数字 Key。

#include <sys/types.h> #include <sys/ipc.h> key_t ftok(const char *pathname, int proj_id);
  • pathname:一个存在的文件路径(通常用当前目录.)。
  • proj_id:一个整数(通常写个字符,如'a')。
  • 返回值:成功返回生成的key_t,两端只要传入相同的路径和 ID,就能得到相同的 Key。
2.shmget—— 创建共享内存
#include <sys/ipc.h> #include <sys/shm.h> int shmget(key_t key, size_t size, int shmflg);
  • key:刚才ftok生成的那个 Key。
  • size:申请多少字节?(建议是 4KB 的整数倍,因为操作系统按页分配内存,如果你申请 4097 字节,OS 实际会分配 8KB,但你只能用 4097)。
  • shmflg:标志位和权限。
    • IPC_CREAT:不存在就创建,存在就获取。
    • IPC_EXCL:配合IPC_CREAT使用,如果存在则报错(用于确保我是第一个创建的)。
    • 权限:类似文件权限,如0666
  • 返回值:成功返回shmid(共享内存 ID),类似文件描述符fd;失败返回 -1。
3.shmat—— 挂接
void *shmat(int shmid, const void *shmaddr, int shmflg);
  • shmidshmget返回的 ID。
  • shmaddr:想挂载到虚拟内存的哪个地址?通常传NULL,让内核自己找个风水宝地。
  • shmflg:读写模式,默认为 0(可读写)。
  • 返回值:成功返回共享内存的首地址(void*),失败返回 -1。
4.shmctl—— 控制/删除
int shmctl(int shmid, int cmd, struct shmid_ds *buf);
  • cmd:常用IPC_RMID(Remove ID),标记删除。
  • 注意IPC_RMID只是标记删除。只有当连接这块内存的所有进程都shmdt(断开)后,物理内存才会真正释放。
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/23 5:25:04

17、OS X 系统中的多任务处理与进程管理

OS X 系统中的多任务处理与进程管理 1. 多任务处理概述 OS X 具备强大的多任务处理能力,它能迅速地在运行的应用程序和系统进程之间分配处理器时间,让用户感觉所有任务都在同时运行。当新应用启动、进程开始,或者其他进程闲置或完全关闭时,系统会实时监控这些任务,并动态…

作者头像 李华
网站建设 2026/5/25 17:12:40

从零构建多语言AI应用:Klavis国际化实战指南 [特殊字符]

面对全球化用户群体时&#xff0c;AI应用常常遭遇语言障碍、文化差异和区域适配等挑战。Klavis开源MCP基础设施为您提供了完整的解决方案&#xff0c;让您的AI应用轻松跨越语言边界&#xff0c;服务全球用户。 【免费下载链接】klavis Klavis AI (YC X25): Open Source MCP Inf…

作者头像 李华
网站建设 2026/5/26 2:17:31

Easy Effects社区预设使用指南:3步解锁专业级音效体验

Easy Effects社区预设使用指南&#xff1a;3步解锁专业级音效体验 【免费下载链接】easyeffects Limiter, compressor, convolver, equalizer and auto volume and many other plugins for PipeWire applications 项目地址: https://gitcode.com/gh_mirrors/ea/easyeffects …

作者头像 李华
网站建设 2026/5/20 13:30:28

LangChain 1.1 版本“中间件“特性解读与实战运用

LangChain v1.1.0 于 2025 年 11 月 25 日发布&#xff0c;中间件&#xff08;Middleware&#xff09;作为 create_agent 的核心特性&#xff0c;为 Agent 开发带来了前所未有的灵活性和可扩展性。本文将深入解读中间件机制&#xff0c;并通过实战示例帮助你快速上手。 一、什么…

作者头像 李华
网站建设 2026/5/20 13:30:16

Qwen3-4B:重新定义智能对话体验的新一代语言模型

Qwen3-4B&#xff1a;重新定义智能对话体验的新一代语言模型 【免费下载链接】Qwen3-4B Qwen3-4B&#xff0c;新一代大型语言模型&#xff0c;集稠密和混合专家&#xff08;MoE&#xff09;模型于一体。突破性提升推理、指令遵循、代理能力及多语言支持&#xff0c;自如切换思维…

作者头像 李华
网站建设 2026/5/25 22:05:23

Factorio智能体5000步规划:从认知断裂到空间推理突破

Factorio智能体5000步规划&#xff1a;从认知断裂到空间推理突破 【免费下载链接】factorio-learning-environment A non-saturating, open-ended environment for evaluating LLMs in Factorio 项目地址: https://gitcode.com/GitHub_Trending/fa/factorio-learning-environ…

作者头像 李华