一、消息队列是操作系统内核地址空间的一个内部链表。消息可以按顺序发送到队列中,也可以以不同方式从队列读取。每个消息队列用唯一的IPC标识符
创建消息队列
int msgget(key_t key,int msgflag)
成功返回队列标识符,错误返回-1
发送消息
int msgsnd(int msqid,struct msgbuf *msgp,sizet msgsz,int msgflg);
队消息队列控制或修改属性
int msgctl(int msqid,int cmd,struct msqid ds*buf);
接受消息
msgrcv(int msqid,struct msgbuf *msgp,sizet msgsz,long msgtype,int msgflg);
qbuf->mtype:槽
关闭进程则消息队列处于阻塞状态
二、共享内存:最有用的进程间通信方式,最快的IPC形式
概念:多个进程共享同一片内存区域(同步机制也可以用互斥锁、信号量)
1、创建和获取共享内存的标识符
int shmget(key_t key,size_t size,int shmflg);
size:段地址大小100byte
shmflg:share memory ID游离于内存
2、连接共享内存
void *shmat(int shmid,const void*shmaddr,int shmflg);
shmaddr:段地址头地址
3、简单的C语言 的读写
创建消息队列
int msgget(key_t key,int msgflag)
成功返回队列标识符,错误返回-1
发送消息
int msgsnd(int msqid,struct msgbuf *msgp,sizet msgsz,int msgflg);
队消息队列控制或修改属性
int msgctl(int msqid,int cmd,struct msqid ds*buf);
接受消息
msgrcv(int msqid,struct msgbuf *msgp,sizet msgsz,long msgtype,int msgflg);
qbuf->mtype:槽
关闭进程则消息队列处于阻塞状态
二、共享内存:最有用的进程间通信方式,最快的IPC形式
概念:多个进程共享同一片内存区域(同步机制也可以用互斥锁、信号量)
1、创建和获取共享内存的标识符
int shmget(key_t key,size_t size,int shmflg);
size:段地址大小100byte
shmflg:share memory ID游离于内存
2、连接共享内存
void *shmat(int shmid,const void*shmaddr,int shmflg);
shmaddr:段地址头地址
3、简单的C语言 的读写