天天看点

Linux线程同步之条件变量

条件变量是线程可用的另一种同步机制。条件变量给多个线程提供了一个会合的场所。条件本身是由互斥量保护的。线程在改变 条件状态前必须首先锁住互斥量。

  条件变量的初始化 pthread_cond_init

  去除初始化 pthread_cond_destroy

  等待 pthread_cond_wait

  满足条件给向进程发送信号 pthread_cond_signal

  下面程序展示了利用条件变量等待另外两个线程满足条件时,第三个进程继续向前执行

#include <stdio.h>

#include <pthread.h>

#include <signal.h>

pthread_mutex_t m1, m2;

pthread_cond_t c1,c2;

pthread_t t1, t2, t3;

void* r1(void *arg)

{

sleep(10); //睡眠10秒

pthread_cond_signal(&c1);

printf("t1 finish\n");

while(1);

}

void* r2(void *arg)

sleep(15);//睡眠15秒

pthread_cond_signal(&c2);

printf("t2 finish\n");

void* r3(void *arg)

pthread_cond_wait(&c1, &m1);

pthread_cond_wait(&c2, &m2);

printf("finish\n");//15秒后线程打印

main()

pthread_mutex_init(&m1, 0);

pthread_mutex_init(&m2, 0);

pthread_cond_init(&c1, 0);

pthread_cond_init(&c2, 0);

pthread_create(&t1, 0, r1, 0);

pthread_create(&t2, 0, r2, 0);

pthread_create(&t3, 0, r3, 0);

  执行结果

  条件变量与互斥量一起使用时,允许线程以无竞争的方式等待特定的条件发生。

  下面程序中,由于在互斥量中等待条件会造成死锁

pthread_t t1,t2;

pthread_mutex_t m1,m2;

pthread_cond_t c;

void *r1(void *d)

while(1)

pthread_mutex_lock(&m1);

printf("wait\n");

pthread_cond_wait(&c,&m2);

pthread_mutex_unlock(&m1);

void *r2(void *d)

printf("signal\n");

pthread_cond_signal(&c);

pthread_cond_init(&c,0);

pthread_mutex_init(&m1,0);

pthread_mutex_init(&m2,0);

pthread_create(&t1,0,r1,0);

pthread_create(&t2,0,r2,0);

/*

pthread_join(t1,0);

pthread_join(t2,0);

pthread_mutex_destroy(&m2);

pthread_mutex_destroy(&m1);

pthread_cond_destroy(&c);*/

  执行结果,程序执行到某一时刻发生死锁,不再向下执行

  改进后的程序,允许线程以无竞争的方式等待,不会发生死锁

pthread_cond_wait(&c,&m1);

最新内容请见作者的github页:http://qaseven.github.io/

继续阅读