System V IPC对象

1、System V IPC对象是什么,分类。

System V IPC对象是用来实现不同进程间通信的方式,IPC对象有3种, 共享内存、消息队列、信号量! 和文件一样,IPC对象在使用之前必须创建!

Linux中查看ipc对象

ipcs 查看所有的ipc对象
ipcs -m 共享内存
ipcs -q 消息队列
ipcs -s 信号量

2、共享内存

2-1、特点

共享内存是一种最为高效的进程间通信方式,进程可以直接读写内存,而不需要任何数据的拷贝 为了在多个进程间交换信息。

内核专门留出了一块内存区,可以由需要访问的进程将其映射到自己的私有地址 空间 进程就可以直接读写这一内存区而不需要进行数据的拷贝,从而大大提高的效率。

由于多个进程共享一段内存,因此也需要依靠某种同步机制,如互斥锁和信号量等。

2-2、实现

1.创建或者打开共享内存
#include <sys/types.h>
#include <sys/ipc.h>
#include <sys/shm.h>
int shmget(key_t key, int size, int shmflg);
/*参数1:键值--ftok()
参数2:共享内存的大小
参数3:权限 IPC_CREAT IPC_EXCL
返回值: 成功 ID 失败 -1
*/
2.映射物理地址
void *shmat(int shmid, const void *shmaddr, int shmflg);
/*参数1:共享内存ID
参数2:映射地址,设置为NULL,自动完成映射
参数3:对共享内存的操作权限 SHM_RDONLY:共享内存只读 0:可读可写的
返回值:成功:映射后的地址 失败 -1
*/
3. 取消映射
int shmdt(const void *shmaddr); //参数:就是映射的地址
4. 删除共享内存
int shmctl(int shmid, int cmd, struct shmid_ds *buf);
/*
参数1:共享内存的ID
参数2: PC_STAT (获取对象属性)
IPC_SET (设置对象属性)
IPC_RMID (删除对象)
参数3:指定IPC_STAT/IPC_SET时用以保存/设置属性 设置为NULL,删除
返回值: 成功 0 失败 -1
*/

3、消息队列

3-1、特点

消息队列是IPC对象的一种。

消息队列由消息队列ID来唯一标识 消息队列就是一个消息的列表。

用户可以在消息队列中添加消息、读取消息等。 消息队列可以按照类型来发送/接收消息。

3-2、实现

1.创建或者打开消息队列
#include <sys/types.h>
#include <sys/ipc.h>
#include <sys/msg.h>
int msgget(key_t key, int flag);
/*参数1:key值 ftok() 参数2:消息队列的访问权限
返回值: 成功 消息队列的ID 失败 -1*/
2.给消息队列中写入消息
int msgsnd(int msqid, const void *msgp, size_t size, int flag);
/*
参数1: 消息队列ID
参数2: 指向消息的地址
参数3: 发送消息的大小:只要内容的大小
参数4: 一般设置为0
返回值:成功 0 失败 -1
*/
3.从消息队列中读取消息
int msgrcv(int msgid, void* msgp, size_t size, long msgtype, int
flag);
/*
参数1: 消息队列ID
参数2: 消息存放的地址
参数3: 消息的大小
参数4: 消息的类型
参数5: 0
返回值:成功 0 失败 -1
*/
4.删除消息队列
int msgctl ( int msgqid, int cmd, struct msqid_ds *buf );
/*
参数1: 消息队列ID
参数2: 指令
IPC_STAT 获取属性
IPC_SET 设置
IPC_RMID 删除
参数3:一般设置为NULL
返回值:成功 0 失败 -1
*/

4、信号量

4-1、特点

信号灯(semaphore),也叫信号量。

它是不同进程间或一个给定进程内部不同线程间同步的机制。

信号灯种类: posix有名信号灯 ---- 使用的是这个,实现进程间的同步问题

                        posix基于内存的信号灯(无名信号灯)

                        System V信号灯(IPC对象)

二值信号灯:值为0或1。与互斥锁类似,资源可用时值为1,不可用时值为0。

计数信号灯:值在0到n之间。用来统计资源,其值代表可用资源数。

4-2、实现

Posix有名信号量实现的方法:
1.创建或者打开信号量
#include <fcntl.h> /* For O_* constants */
#include <sys/stat.h> /* For mode constants */
#include <semaphore.h>
sem_t *sem_open(const char *name, int oflag);
sem_t *sem_open(const char *name, int oflag,mode_t mode, unsigned int
value);
/*
参数1:信号量的名字
参数2:操作 O_CREAT O_EXCL
参数3:权限 0666
参数4:信号的初始值 0 1*/
2.P操作
#include <semaphore.h>
int sem_wait(sem_t *sem); //参数 信号量
3.V操作
#include <semaphore.h>
int sem_post(sem_t *sem); //参数 信号量
Link with -pthread.
4.信号量关闭
sem_close(sem_t *);
5.信号量的删除
sem_ulink(信号量名);

  • 10
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值