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

进程间通信(IPC)----共享内存

进程间通信(IPC)的共享内存机制允许不同进程直接访问同一块物理内存区域,是速度最快的IPC方式(无需数据拷贝)。


一、共享内存核心概念

1. 基本原理
  • 共享内存区域:由内核管理的特殊内存段,可被多个进程映射到自身地址空间。
  • 零拷贝:进程直接读写内存,无需通过内核缓冲区(如管道/消息队列需要)。
  • 需同步:必须配合信号量/互斥锁等机制,避免数据竞争。
2. 生命周期
  • 创建shmget(System V)或 shm_open(POSIX)
  • 映射shmatmmap
  • 销毁shmctlshm_unlink

二、System V 共享内存基础示例

1. 创建共享内存
#include <sys/ipc.h>
#include <sys/shm.h>int main() {key_t key = ftok("shmfile", 65); // 生成唯一keyint shmid = shmget(key, 1024, 0666|IPC_CREAT); // 创建1024字节共享内存char *str = (char*) shmat(shmid, (void*)0, 0); // 映射到进程地址空间sprintf(str, "Hello Shared Memory!"); // 写入数据shmdt(str); // 解除映射return 0;
}
2. 另一个进程读取数据
int main() {key_t key = ftok("shmfile", 65);int shmid = shmget(key, 1024, 0666);char *str = (char*) shmat(shmid, (void*)0, 0);printf("Data read: %s\n", str);shmdt(str);shmctl(shmid, IPC_RMID, NULL); // 销毁共享内存return 0;
}

三、POSIX 共享内存进阶示例

1. 使用 mmapshm_open
#include <sys/mman.h>
#include <sys/stat.h>
#include <fcntl.h>int main() {const char* name = "/my_shm";int fd = shm_open(name, O_CREAT | O_RDWR, 0666); // 创建POSIX共享内存对象ftruncate(fd, 1024); // 设置大小char *ptr = mmap(0, 1024, PROT_READ|PROT_WRITE, MAP_SHARED, fd, 0);sprintf(ptr, "Hello POSIX SHM!");munmap(ptr, 1024);close(fd);shm_unlink(name); // 删除共享对象return 0;
}
2. 配合信号量同步
#include <semaphore.h>// 写入进程
sem_t *sem = sem_open("/my_sem", O_CREAT, 0666, 1); // 初始化信号量为1
sem_wait(sem); // P操作
sprintf(ptr, "New Data with Sync");
sem_post(sem); // V操作// 读取进程
sem_t *sem = sem_open("/my_sem", 0);
sem_wait(sem);
printf("Data: %s", ptr);
sem_post(sem);

四、深入理解共享内存

1. 性能优势场景
  • 大数据传输:如视频处理、科学计算
  • 实时性要求高:高频交易系统
2. 风险与缺陷
  • 数据竞争:必须强制同步
  • 内存泄漏:需显式销毁共享段
  • 安全风险:所有进程均可访问
3. 高级技术扩展
  • 匿名共享内存mmap 使用 MAP_ANONYMOUS,适用于父子进程
  • 共享内存数据库:Redis的持久化内存设计
  • 跨网络共享内存:如RDMA(远程直接内存访问)

五、关键系统调用对比

函数用途System VPOSIX
shmget创建/获取共享内存✔️
shmat映射共享内存✔️
shmdt解除映射✔️
mmap内存映射文件/共享内存✔️
shm_open创建POSIX共享内存对象✔️

通过上述示例和解析,可以掌握共享内存的核心原理与实践技巧。实际开发中需结合场景选择System V或POSIX标准,并始终关注同步问题。

http://www.xdnf.cn/news/328.html

相关文章:

  • 热蛋白质组分析技术(TPP)在前列腺癌治疗研究中的应用
  • c++ map与unordered_map的比较
  • 抖音“碰一碰发视频”源码搭建:碰一碰定制化开发
  • 西门子 博途 软件 崩溃
  • 接口自动化测试(二)
  • 不一样的flag 1(迷宫题)
  • 《软件设计师》复习笔记(11.2)——开发方法、产品线、软件复用、逆向
  • 从零实现Git安装、使用
  • Java 爬虫按关键字搜索淘宝商品:实现与优化
  • MARA/MARC表 PSTAT字段
  • [特殊字符] 当Docker遇上大模型:本地运行LLM的奇幻漂流 [特殊字符]
  • 高阶数据结构 图 (上)
  • UR5e机器人动力学
  • 大模型如何突破“知识盲区”?一场静悄悄的技术革命正在发生
  • [Vue3]动态引入图片
  • NHANES指标推荐:CMI
  • 阿里云服务器搭建开源版禅道
  • 高级工程师评审-隐藏的条件都有哪些
  • gitee提交大文件夹
  • MapWindow GIS:开源的GIS程序 库和工具,适用于基于C#和.NET的应用程序
  • 电路安全智控系统与主机安全防护系统主要功能是什么
  • Spring lazy-init 懒加载的原理
  • Vue自定义指令-防抖节流
  • 易派客九周年再启新程 数智赋能工业供应链高质量发展
  • 开发者调研:使用AI工具后需求交付效率提升210%
  • 安卓手机万能遥控器APP推荐
  • Qt 入门 5 之其他窗口部件
  • 2025年4月18日漏洞文字版表述一句话版本(漏洞危害以及修复建议),通常用于漏洞通报中简洁干练【持续更新中】,漏洞通报中对于各类漏洞及修复指南
  • Vue3+Openlayers教程导航页【目录】
  • DeepSeek 部署中的常见问题及解决方案