2.6作业

本文详细介绍了如何使用C++的pthread库中的mutex(互斥锁)和cond(条件变量)来实现线程间的同步,展示了生产者-消费者模型在多线程环境下的应用。
摘要由CSDN通过智能技术生成

两个线程实现同步代码示例

#include <myhead.h>
 
int num=4;
pthread_mutex_t mutex;
pthread_cond_t cond;
 
void *task1(void *arg){
	while(1){
		sleep(1);
		printf("生产者生产了三辆小汽车\n");
		pthread_cond_broadcast(&cond);
	}
	pthread_exit(NULL);
}
 
void *task2(void *arg){
	while(1){
		sleep(1);
		pthread_mutex_lock(&mutex);
		pthread_cond_wait(&cond,&mutex);
		printf("消费者消费了一辆小汽车\n");
		pthread_mutex_unlock(&mutex);
	}
	pthread_exit(NULL);
}
 
 
int main(int argc, const char *argv[])
{
	pthread_t tid1,tid2,tid3,tid4;
 
	pthread_mutex_init(&mutex,NULL);
 
	pthread_cond_init(&cond,NULL);
	if(pthread_create(&tid1,NULL,task1,NULL)!=0){
		perror("pthread_create task1 error");
		return -1;
	}
 
	if(pthread_create(&tid2,NULL,task2,NULL)!=0){
		perror("pthread_create task2 error");
		return -1;
	}
	if(pthread_create(&tid3,NULL,task2,NULL)!=0){
		perror("pthread_create task1 error");
		return -1;
	}
 
	if(pthread_create(&tid4,NULL,task2,NULL)!=0){
		perror("pthread_create task2 error");
		return -1;
	}
	pthread_join(tid1,NULL);
	pthread_join(tid2,NULL);
	pthread_join(tid3,NULL);
	pthread_join(tid4,NULL);
 
	pthread_mutex_destroy(&mutex);
	pthread_cond_destroy(&cond);
	return 0;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值