一、管程来解决生产者/消费者问题
1)
<span style="font-size:18px;">Struct Monitor
{
condition NF,NE;
int Buffer[n];
int k = 0,t = 0,count = 0;
define Add(int),Remove(int);
use wait(),signal(),check(),release();
void init() //初始化局部变量和条件变量
{
count = 0;k = 0;t = 0;NF = 0;NE = 0;
}
vodi Add(int i)
{
check();
if(count ==n) wait(NF);
Buffer[k] = i;
k = (k+1)%n;
count++;
signal(NE);
release();
}
void Remove(int &i)
{
check();
if(count == 0)wait(NE);
i = Buffer[t];
t = (t+1)%n;
count--;
signal(NF);
release();
}
}</span></span>