目录
1.信号量的引例
不加控制模拟使用打印机:
比如:进程a和进程b模拟访问打印机,进程a输出第一个字符‘a’表示开始使用打印机,输出第二个字符‘a’表示结束使用,b进程操作与a进程操作相同。
思路:
具体代码如下:
//a.c
#include <stdio.h>
#include <stdlib.h>
#include <unistd.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 <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);//使用结束后去做其他事情
}
}
其实,正确的结果应该是:
由于打印机同一时刻只能被一个进程使用,所以输出结果不应该出现ABAB这样交替的结果;我们上面得到的都是错误的结果。
2.信号量的介绍
信号量就是控制某个进程能够对某个资源进行访问;保证同一时刻只能由一个进程对某个资源进程访问
信号量是一个特殊的变量,对信号量的操作都是一个原子操作(不能被打断的操作);
打印机
信号量是一个特殊的变量,一般取正数值。它的值代表允许访问的资源数目,获取