pthread_cond_wait和pthread_cond_signal函数

3 篇文章 0 订阅

条件变量与相关pthread调用
线程调用描述
pthread_cond_init创建一个条件变量
pthread_cond_destroy撤销一个条件变量
pthread_cond_wait阻塞以等待一个信号
pthread_cond_signal向另一个线程发送信号来唤醒它

pthread_cond_broadcast

向多个线程发信号来让他们全部唤醒

pthread_cond_wait函数

      pthread_cond_wait(pthread_cond_t *cond, pthread_mutex_t *mutex)函数传入的参数mutex用于保护条件,因为我们在调用pthread_cond_wait时,如果条件不成立我们就进入阻塞,但是进入阻塞这个期间,如果条件变量改变了的话,那我们就漏掉了这个条件。因为这个线程还没有放到等待队列上,所以调用pthread_cond_wait前要先锁互斥量,即调用pthread_mutex_lock(),pthread_cond_wait在把线程放进阻塞队列后,自动对mutex进行解锁,使得其它线程可以获得加锁的权利。这样其它线程才能对临界资源进行访问并在适当的时候唤醒这个阻塞的进程。当pthread_cond_wait返回的时候又自动给mutex加锁。

转于:http://sgy618.itpub.net/post/42829/513424 


 pthread_cond_signal函数:

      pthread_cond_signal函数的作用是发送一个信号给另外一个正在处于阻塞等待状态的线程,使其脱离阻塞状态,继续执行.如果没有线程处在阻塞等待状态,pthread_cond_signal也会成功返回。
      但使用pthread_cond_signal不会有“惊群现象”产生,他最多只给一个线程发信号。假如有多个线程正在阻塞等待着这个条件变量的话,那么 是根据各等待线程优先级的高低确定哪个线程接收到信号开始继续执行。如果各线程优先级相同,则根据等待时间的长短来确定哪个线程获得信号。但无论如何一个 pthread_cond_signal调用最多发信一次。另外,互斥量的作用一般是用于对某个资源进行互斥性的存取,很多时候是用来保证操作是一个原子性的操作,是不可中断的。
pthread_cond_signal函数与条件变量的典型应用就是用来实现producer/consumer模型。

转于:http://hi.baidu.com/wgcno7/blog/item/eeb4fb15539c7802c93d6d85.html


生产者-消费者例子(现代操作系统 第三版):

/*************************************************************************
	> File Name: mutex_cond.c
	> Created Time: Thu 17 Jul 2014 07:27:48 PM CST
 ************************************************************************/

#include<stdio.h>
#include<pthread.h>
#define MAX 100000000
pthread_mutex_t the_mutex;
pthread_cond_t condc, condp;
int buffer = 0;

void *producer(void *ptr)
{
	int i;
	for(i = 1; i<=MAX; ++i)
	{
		pthread_mutex_lock(&the_mutex);
		if(buffer != 0) pthread_cond_wait(&condp, &the_mutex);
		buffer = i;
		printf("%d\n",buffer);
		pthread_cond_signal(&condc);
		pthread_mutex_unlock(&the_mutex);
	}
	pthread_exit(0);
}

void *consumer(void *ptr)
{
	int i;
	for(i = 1; i<=MAX; ++i)
	{
		pthread_mutex_lock(&the_mutex);
		if(buffer == 0) pthread_cond_wait(&condc, &the_mutex);
		buffer = 0;
		printf("%d\n",buffer);
		pthread_cond_signal(&condp);
		pthread_mutex_unlock(&the_mutex);
	}
	pthread_exit(0);
}
int main()
{
	pthread_t pro,con;
	pthread_mutex_init(&the_mutex, 0);
	pthread_cond_init(&condc,0);
	pthread_cond_init(&condp,0);
	pthread_create(&pro, 0, producer, 0);
	pthread_create(&con, 0, consumer, 0);
	pthread_join(pro, 0);
	pthread_join(con, 0);
	pthread_cond_destroy(&condc);
	pthread_cond_destroy(&condp);
	pthread_mutex_destroy(&the_mutex);
}


  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值