信号量

作者: NiNko | 来源:发表于2020-03-12 18:47 被阅读0次

多道程序环境下,进程并发执行,不同进程存在着不同的制约关系,为了协调进程的制约关系,引入了进程同步概念。

同步亦称为直接制约关系,指多个进程在某些位置上协调他们的工作次序而等待、传递信息所产生的制约关系。

互斥也称间接制约关系,当一个进程使用临界区资源时,另一个进程必须等待,当前一个进程释放资源后,才能访问临界区资源。


信号量机制可以用来解决互斥和同步问题,他只能被两个标准原语wait(S)和signal(S)访问,也可记作P操作和V操作。原语指完成某种功能且不能被分割,不被中断执行的操作序列,通常由硬件实现。

  • 整型信号量

整型信号量被定义为一个用于表示资源数目的整型量S,wait和signal如下

wait(S){
    while(S<=0);
    S=S-1;
}
signal(S){
    S=S+1;
}

wait操作中,只要信号量S<=0,就会不断测试。该机制使进程处于忙等状态

  • 记录型信号量

除了一个代表资源数目的整型变量外,还增加了一个进程链表L,用于链接所有等待该资源的进程。

typedef struct{
    int value;
    struct process *L;
} semaphore
void wait(semaphore S){
    S.value--;
    if(S.value<=0){
        add this process to S.L;
        block(S.L)
    }
}
void signal(semaphore S){
    S.value++;
    if(S.value<=0){
        remove a process P from S.L;
        wakeup(P);
    }
}

wait操作,S.value--表示请求一个资源,当小于0时,表示资源分配完毕,该进程自我阻塞,并插入等待队列。

signal操作,表示释放一个该类资源,若资源加1之后S.value仍然小于0,表示等待队列中仍有进程被阻塞,因此使用wakeup原语唤醒进程。

  • 信号量实现同步
semaphore S=0;
P1(){
    ...
    x;
    V(S);
}
P2(){
    ...
    P(S);
    y;
}

只有x语句执行完,y语句才能执行。若P2先执行,到P(S)时,S为0,阻塞。进程P1中的x语句执行完之后,执行V操作,把P2从阻塞队列中唤醒,执行P2进程。

  • 信号量实现互斥
semaphore S=1;
P1(){
    ...
    P(S);
    进程P1临界区;
    V(S);
}
P2(){
    ...
    P(S);
    进程P2临界区;
    V(S);
}

当没有进程进入临界区时,任意进程要进入临界区,需要先执行P操作,将S值减为0,然后进入临界区。此时别的进程要进入临界区,执行P操作时会阻塞。当临界区的进程执行完后,执行V操作,S值变为1,其他进程才可以进入临界区。

相关文章

  • 第二章 信号量机制及几个经典例题

    1.信号量机制 信号量机制即利用pv操作来对信号量进行处理。 什么是信号量?信号量(semaphore)的数据结构...

  • iOS底层--GCD应用

    手动目录GCD简介信号量信号量的理解信号量的使用信号量的代码实操信号量阻塞哪里的任务?栅栏函数dispatch_b...

  • dispatch_semaphore_t

    dispatch_semaphore_t :信号量包含三个函数:1、创建信号量 2、增加信号量 3、削减信号量 注...

  • [java并发编程]基于信号量semaphore实现限流器

    [TOC] 一、什么是信号量 “信号量”在编程术语中使用单词semaphore,那什么是“信号量”?信号量就好比你...

  • iOS GCD信号量的使用

    什么是信号量 信号量是一种特殊的变量,访问具有原子性。 当信号量大于0时执行wait操作信号量会减1, 当信号量为...

  • dispatch_semaphore_t

    一、信号量 semaphore叫做“信号量” 1、创建信号量dispatch_semaphore_create(l...

  • GCD信号量使用

    一、信号量 semaphore叫做“信号量” 1、创建信号量dispatch_semaphore_create(l...

  • 理解操作系统之信号量的应用

    利用信号量实现进程互斥(模式) 利用信号量实现前驱关系(模式) 利用记录型信号量实现同步(模式) 1.利用信号量实...

  • FreeRTOS学习笔记(4)——信号量

    一、头文件 二、二值信号量 2.1 运作机制 创建信号量时,系统会为创建的信号量对象分配内存,并把可用信号量初始化...

  • CRTOS——互斥信号量

    互斥信号量等待操作: 1、等待互斥信号量,互斥信号量未被占有(锁定次数为0),占有过程中将信号量拥有者指向任务,并...

网友评论

      本文标题:信号量

      本文链接:https://www.haomeiwen.com/subject/orapjhtx.html