【Linux/OS/Network】XSI IPC(消息队列,信号量,共享内存)

本文深入探讨XSI IPC,包括消息队列、信号量和共享内存。消息队列提供了进程间数据块传递,不同于管道的字节流方式。信号量用于资源访问控制,确保数据操作的互斥与同步。共享内存允许多个进程共享存储区,通常配合信号量使用。文中详细介绍了各自的数据结构、函数接口及应用场景。
摘要由CSDN通过智能技术生成

XSI IPC 包括消息队列、信号量以及共享内存,他们都依托标识符和键来实现的,这就像是管道靠文件描述符来实现一样


IPC主题一:消息队列

一、什么是消息队列

消息队列提供了一种从一个进程向另一个进程发送一个数据块的方法。每个数据块都被认为是有一个类型,接收者进程接收的数据块可以有不同的类型值。我们可以通过发送消息来避免命名管道的同步和阻塞问题。消息队列与管道不同的是,消息队列是基于消息的,而管道是基于字节流的,且消息队列的读取不一定是先入先出。消息队列与命名管道有一样的不足,就是每个消息的最大长度是有上限的(MSGMAX),每个消息队列的总的字节数是有上限的(MSGMNB),系统上消息队列的总数也有一个上限(MSGMNI)。

这里写图片描述

二、IPC对象数据结构

内核为每个IPC对象维护一个数据结构(/usr/include/linux/ipc.h)
struct ipc_perm {
key_t __key; /* Key supplied to xxxget(2) */
uid_t uid; /* Effective UID of owner */
gid_t gid; /* Effective GID of owner */
uid_t cuid; /* Effective UID of creator */
gid_t cgid; /* Effective GID of creator */
unsigned short mode; /* Permissions */
unsigned short __seq; /* Sequence number */
};

这里写图片描述

消息队列,共享内存和信号量都有这样⼀一个共同的数据结构。

三、消息队列结构(/usr/include/linux/msg.h)

这里写图片描述

可以看到第一个条目就是IPC结构体,即是共有的,后面的都是消息队列所私有的成员。消息队列是用链表实现的。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值