进程间通信(信号量通信)

来源:互联网 发布:java数组从小到大排序 编辑:程序博客网 时间:2024/06/05 03:02

当我们在实际编程时会发现,有时候多个进程或线程共用一段代码,我们要确保某个时刻只有一个进程或线程对这段代码进行访问。为了防止多个程序同时访问一个共享资源引发问题,可以用信号量控制临界区域的访问。
信号量分为以下三种:
System V信号量,在内核中维护,可用于进程或线程间的同步,常用于进程的同步。
Posix有名信号量,一种来源于POSIX技术规范的实时扩展方案,可用于进程或线程间的同步,常用于线程。
Posix基于内存的信号量,存放在共享内存区中,可用于进程或线程间的同步。
进程获得共享资源执行的操作:
1,测试控制该资源的信号量。
2,若信号量的值为正,则进程可以使用该资源。然后将信号量值减1,表示它使用了一个资源单位。此进程使用完共享资源后对应的信号量应该加1,以便其他进程使用。
3,若对信号量进行减1时,信号量的值为0,则进程进入阻塞休息状态,直至信号量值大于0,进程被唤醒,返回第一步。
为了正确地实现信号量,信号量的值测试及减1操作应当是原子操作(原子操作是不可分割的,在执行完毕前不会被其他任务或事件中断),为此信号量通常是在内核中实现的。
信号量是一种特殊的变量,只允许等待和发送信号这两种操作。
P(信号量变量):用于等待
V(信号量变量):用于发送信号
#include <sys/sem.h>
#include <sys/ipc.h>
#include <sys/type.h>
int semget(key_t key,int num_sems,int sem_flags);
int semop(int sem_id,int num_sems,int sem_flags);

int semctl(int sem_id,int sem_num,int command,union semun arg);



未完,待续。。。

0 0
原创粉丝点击