系统V(五)的IPC原理

- 假设用户中有P1,P2,P3三个进程,那么在SYS-V系统内核中存在IPC对象以供它们进行通信
- 在IPC对象中使用KEY来表示IPC对象
- 那么每个进程都会使用IPC对象,每个进程打开IPC对象都有相对应的id,然后进程就会根据id来操作IPC对象
- 一般使用的IPC对象有:共享内存、消息队列、信号量等
如何在系统中查看IPC对象:
ipcs -a 表示查看系统中全部IPC对象

共享内存
共享内存的原理

- 两个进程共同将物理内存通过映射方式进行共享
- 查看系统存在的共享内存:
ipcs -m
创建共享内存步骤
- 获取共享内存对象的id
- 将共享内存映射到本进程虚拟内存空间的某个区域
- 当不再使用时,解除映射关系
- 当没有进程再需要这块共享内存时候,删除它
代码实现:
1.创建IPC对象:shmget

1.1创建KEY:key_t ftok(const char *pathname, int proj_id);
2.映射共享内存:shmat

3.解除映射:shmdt



代码运行结果:


本文深入探讨了系统V(五)的进程间通信(IPC)原理,包括共享内存、消息队列和信号量等核心概念。详细介绍了共享内存的创建、映射、使用及销毁流程,并提供了关键的系统调用如shmget、shmat、shmdt的说明。
1427

被折叠的 条评论
为什么被折叠?



