1.信号量的定义:
信号量是一个特殊的变量,一般取正数值。它的值代表允许访问的资源数目, 获取资源时,需要对信号量的值进行原子减一,该操作被称为p操作。当信号量值为0时,代表没有资源可用,p操作会阻塞。释放资源时,需要对信号量的值进行原子加一,该操作被称为v操作。信号量主要用来同步进程。 信号量的值如果只取0,1,将其称为二值信号量。如果信号量的值大于 1,则称之为计数信号量。注意:正数值;
加一减一是一个原子操作;
2.临界资源和临界区的概念:
临界资源:计算机的软硬件资源;同一时刻,只允许一个进程或者线程访问的资源;
临界区:访问临界资源的代码段;
3.信号量的一个例子:
不加控制模拟使用打印机:
比如:进程 a 和进程 b 模拟访问打印机,进程 a 输出第一个字符‘ a’表示开始使用打印机,输出第二个字符‘ a’表示结束使用, b 进程操作与 a 进程相同。(由于打印机同一时刻只能被一个进程使用,所以输出结果不应该出现 abab这样交替的结果)
4.代码:
a.c
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <string.h>
#include <assert.h>
int main()
{
int i = 0;
for (; i < 5; i++)
{
printf("A");
fflush(stdout);
int n = rand() % 3;
sleep(n);
printf("A");
fflush(stdout);
n = rand() % 3;
sleep(n);
}
}
b.c
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <string.h>
#include <assert.h>
int main()
{
int i = 0;
for (; i < 5; i++)
{
printf("B");
fflush(stdout);
int n = rand() % 3;
sleep(n);
printf("B");
fflush(stdout);
n = rand() % 3;
sleep(n);
}
}
信号:
信号量用处
//运行的时候:./a& ./b&
目的:A,B成对出现