双线程交替修改变量 条件变量

这里用到了条件变量。对于条件变量,它的作用是可以调度各个进程阻塞或者唤醒。每个条件变量都有两个操作:wait和signal。wait操作可以把自身进程放于等待队列中,并且紧急等待队列非空的情况下可以唤醒第一个等待者。signal可以唤醒等待队列进程中的第一个等待者,然后本进程进入紧急等待队列的末尾。

#include
#include
#include
#include

#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;
}

 

你可能感兴趣的:(操作系统)