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(信号量名);