这里用到了条件变量。对于条件变量,它的作用是可以调度各个进程阻塞或者唤醒。每个条件变量都有两个操作:wait和signal。wait操作可以把自身进程放于等待队列中,并且紧急等待队列非空的情况下可以唤醒第一个等待者。signal可以唤醒等待队列进程中的第一个等待者,然后本进程进入紧急等待队列的末尾。
#include<stdio.h>
#include<unistd.h>
#include<stdlib.h>
#include<pthread.h>
#define COUNT 20
static int i = 1;
pthread_mutex_t mutex = PTHREAD_MUTEX_INITIALIZER;
//分别是偶数和奇数的信号量
pthread_cond_t even = PTHREAD_COND_INITIALIZER;
pthread_cond_t uneven = PTHREAD_COND_INITIALIZER;
//打印奇数的
void* funA(void*)
{
while(i <= COUNT)
{
//进入临界区之前先加锁
pthread_mutex_lock(&mutex);
if(i % 2 != 0)
{
printf("funA : %d\n",i);
++i;
//可以唤醒等待队列中的偶数修改线程
pthread_cond_signal(&even);
}
else{
//如果不是的话则需要等待
pthread_cond_wait(&uneven, &mutex);
}
//去掉锁
pthread_mutex_unlock(&mutex);
}
}
//打印偶数的
void* funB(void*)
{
while(i <= COUNT)
{
pthread_mutex_lock(&mutex);
if(i % 2 == 0)
{
printf("funB : %d\n",i);
++i;
pthread_cond_signal(&uneven);
}
else{
pthread_cond_wait(&even, &mutex);
}
pthread_mutex_unlock(&mutex);
}
}
int main()
{
pthread_t tid1, tid2;
pthread_create(&tid1, NULL, funA, NULL);
pthread_create(&tid2, NULL, funB, NULL);
pthread_join(tid1, NULL);
pthread_join(tid2, NULL);
return 0;
}