为什么pthread条件变量不起作用

时间:2016-12-16 00:17:21

标签: c multithreading pthreads mutex race-condition

我正在编码以模拟卖票情况:
当票数为0时,两个线程逐个销售一些票证,一个线程显示sold out 所以我尝试使用条件变量。这是代码:

int a = 10;
pthread_mutex_t mtx;
pthread_cond_t cond;


void * funca(void *p)
{
    while(1)
    {
        pthread_mutex_lock(&mtx);
        if (a == 0)
        {
            break;
        }
        a--;
        pthread_mutex_unlock(&mtx);
        sleep(1);
    }
    pthread_mutex_unlock(&mtx);
    pthread_cond_broadcast(&cond);
    return NULL;
}

void * funcb(void *p)
{
    while(1)
    {
        pthread_mutex_lock(&mtx);
        if (a == 0)
        {
            break;
        }
        a--;
        pthread_mutex_unlock(&mtx);
        sleep(1);
    }
    pthread_mutex_unlock(&mtx);
    pthread_cond_broadcast(&cond);
    return NULL;
}

void * funcc(void *p)
{
    pthread_mutex_lock(&mtx);
    while(a != 0)
    {
            pthread_cond_wait(&cond, &mtx);
            printf("I'm nothing");
    }
    pthread_mutex_unlock(&mtx);
    printf("sold out\n");
    return NULL;
}

然而,当我执行上面的代码时,我得到一个无限循环,打印了许多I'm nothing

1 个答案:

答案 0 :(得分:3)

您尚未初始化互斥锁和条件变量。声明变量时,请使用:

pthread_mutex_t mtx = PTHREAD_MUTEX_INITIALIZER;
pthread_cond_t cond = PTHREAD_COND_INITIALIZER;

funca()funcb()两个相同的函数也没有意义,你可以让两个不同的线程执行相同的函数。