Chinaunix首页 | 论坛 | 博客
  • 博客访问: 74992
  • 博文数量: 15
  • 博客积分: 10
  • 博客等级: 民兵
  • 技术积分: 80
  • 用 户 组: 普通用户
  • 注册时间: 2012-09-20 19:01
文章分类

全部博文(15)

文章存档

2016年(1)

2015年(1)

2014年(1)

2012年(12)

分类: C/C++

2014-10-10 11:52:50

原文地址:IPC 三种通信机制 作者:ahutwgs

最近看了,IPC三种通信机制,OK,小写自己的收获吧。

IPC三种通信机制是指:信号量、共享内存、消息队列,一开始看得时候感觉有点吃力,当我模仿书上的程序写了写代码之后,就慢慢的理解了。

信号量:通过操作系统中的PV操作来实现;
共享内存:申请一块内存,进程A往共享内存中写,其他的进程就可以通过读出共享内存中的内容来获取进程A所传送的信息;
消息队列:创建一个消息队列,进程A往队列里面写,那么进程B通过读队列中的容来获取进程A传送的信息。

具体的实现其实就是用三组函数来实现的,而且形式都是很有相似性的。

信号量:
#include
int semget(key_t key,int num_sems,int sem_flgs);
int semctl(int sem_id,int sem_num,int command...);
int semop(int sem_id,struct sembuf *sem_ops,size_t num_sem_ops);

每个函数的功能和参数的意义在手册中都能找到。


1、semget                创建一个信号量或者获取一个已知信号量的键
key:不相关的进程可以通过他来访问同一个信号量
num_sems:需要的信号量数目。几乎总是1
sem_flags:一组标志,例如IPC_CREAT;
返回值是信号量标志符,给其他信号量函数使用


2、semctl:
sem_id:信号量标志符,semget的返回值
sem_ops:信号量编号,一般取0
command:   就不解释了,在手册中有详细的解释,我就偷偷懒吧。

3、semop
用于改变信号量的值
struct sembuf{
short sen_nums;            //信号量编号,一般取0
short sem_op;               //一般-1是P操作,1是V操作
short sem_flag;            //通常设置为UNDO
}



共享内存
允许两个不像关的进程访问同一个逻辑地址
#include
1、int shmget(key_t key,size_t size,int shmflag);
2、void *shmat(int shm_id,const void *shm_addr,int shm_flag);
3、int shmctl(int shm_id,int cmd,struct shmid_ds *buf);
4、int shmdt(const void *shm_addr);

参数的常用值:
1、shmflag:0666|IPC_CREAT
2、shmaddr=0           shm_flag=0
3、cmd=IPC_SET  cmd=IPC_RMID




消息队列:
提供从一个进程向另一个进程发送一个数据块的方法
#include
int msgget(key_t key,int msgflg);
int msgctl(int magid,int cmd,struct msgid_ds *buf);
int msgsnd(int msgid,void *msg_ptr,size_t msg_sz,int msgflag);
int msgrcv(int msgid,void *msg_ptr,size_t msg_sz,long int msg_type,int msgflag);


省略了许多的说明,这些函数使用都可以在手册中查到。OK! 偷下懒~










阅读(1638) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~