Linux 下 C 语言编程--进程通信、消息管理
前言:Linux 下的进程通信(IPC)
Linux 下的进程通信(IPC)
1.POSIX 无名信号量
2.SystemV 信号量
3.SystemV 消息队列
4.SystemV 共享内存
--------------------------------------------------------------------------------
1。POSIX 无名信号量如果你学习过操作系统,那么肯定熟悉 PV 操作了.PV 操作是原子操作.
也就是操作是不可以中断的,在一定的时间内,只能够有一个进程的代码在 CPU 上面执行.在
系统当中,有时候为了顺利的使用和保护共享资源,大家提出了信号的概念.假设我们要使用
一台打印机,如果在同一时刻有两个进程在向打印机输出,那么最终的结果会是什么呢.为了
处理这种情况,POSIX 标准提出了有名信号量和无名信号量的概念,由于 Linux 只实现了无名
信号量,我们在这里就只是介绍无名信号量了.信号量的使用主要是用来保护共享资源,使的
资源在一个时刻只有一个进程所拥有.为此我们可以使用一个信号灯.当信号灯的值为某个值
的时候,就表明此时资源不可以使用.否则就表>示可以使用.为了提供效率,系统提供了下面
几个函数
POSIX 的无名信号量的函数有以下几个:
#include
intsem_init(sem_t*sem,intpshared,unsignedintvalue);
intsem_destroy(sem_t*sem);
intsem_wait(sem_t*sem);
intsem_trywait(sem_t*sem);
intsem_post(sem_t*sem);
intsem_getvalue(sem_t*sem);
sem_init 创建一个信号灯,并初始化其值为 value.pshared 决定了信号量能否在几个进程间共
享.由于目前 Linux 还没有实现进程间共享信号灯,所以这个值只能够取 0.sem_destroy 是用
来删除信号灯的.sem_wait 调用将阻塞进程,直到信号灯的值大于 0.这个函数返回的时候自动
的将信号灯的值的件一.sem_post 和 sem_wait 相反,是将信号灯的内容加一同时发出信号唤
醒等待的进程..sem_trywait 和 sem_wait 相同,不过不阻塞的,当信号灯的值为 0 的时候返回
EAGAIN,表示以后重试.sem_getvalue 得到信号灯的值.
由于 Linux 不支持,我们没有办法用源程序解释了.
这几个函数的使用相当简单的.比如我们有一个程序要向一个系统打印机打印两页.我们首先
创建一个信号灯,并使其初始值为 1,表示我们有一个资源可用.然后一个进程调用 sem_wait
由于这个时候信号灯的值为 1,所以这个函数返回,打印机开始打印了,同时信号灯的值为 0了.
如果第二个进程要打印,调用 sem_wait 时候,由于信号灯的值为 0,资源不可用,于是被阻塞了.
当第一个进程打印完成以后,调用 sem_post 信号灯的值为 1 了,这个时候系统通知第二个进
程,于是第二个进程的 sem_wait 返回.第二个进程开始打印了.
不过我们可以使用线程来解决这个问题的.我们会在后面解释什么是线程的.编译包含上面这