8.3-IO进程线程-作业

编写一个程序,开启3个 线程,这3个线程的ID分别为ABC,每个线程将自己的ID在屏幕上打印10遍,要求输出结果必须按ABC的顺序显示,如ABCABC……依次递推;
提示:A只能叫醒B,B只能唤醒C,C只能唤醒A;

#include <stdio.h>
#include <pthread.h>
#include <string.h>

pthread_mutex_t mutex;//互斥锁
pthread_cond_t cond0;//条件变量
pthread_cond_t cond1;//条件变量
pthread_cond_t cond2;//条件变量
int flag = 0;
void* callA(void*arg)
{
	for(int i=0;i<10;i++)
	{
		pthread_mutex_lock(&mutex);//上锁
		if(flag != 0)
		{
			pthread_cond_wait(&cond0,&mutex);//休眠,解锁,被唤醒后上锁
		}
		printf("A");
		flag = 1;
		pthread_cond_signal(&cond1);//唤醒cond
		pthread_mutex_unlock(&mutex);//解锁
	}
}

void* callB(void*arg)
{
	char temp;
	for(int i=0;i<10;i++)
	{
		pthread_mutex_lock(&mutex);//上锁
		if(flag != 1)
		{
			pthread_cond_wait(&cond1,&mutex);//休眠,解锁,被唤醒后上锁
		}
		printf("B");
		flag = 2;
		pthread_cond_signal(&cond2);//唤醒
		pthread_mutex_unlock(&mutex);//解锁
	}
}
void* callC(void*arg)
{
	char temp;
	for(int i=0;i<10;i++)
	{
		pthread_mutex_lock(&mutex);//上锁
		if(flag != 2)
		{
			pthread_cond_wait(&cond2,&mutex);//休眠,解锁,被唤醒后上锁
		}
		printf("C\n");
		flag = 0;
		pthread_cond_signal(&cond0);//唤醒
		pthread_mutex_unlock(&mutex);//解锁
	}
}


int main(int argc, const char *argv[])
{
	//创建条件变量
	if(pthread_cond_init(&cond0,NULL) != 0)
	{
		perror("pthread_cond_init");
		return -1;
	}	
	if(pthread_cond_init(&cond1,NULL) != 0)
	{
		perror("pthread_cond_init");
		return -1;
	}
	if(pthread_cond_init(&cond2,NULL) != 0)
	{
		perror("pthread_cond_init");
		return -1;
	}
	//创建互斥锁
	if(pthread_mutex_init(&mutex,NULL) != 0)
	{
		perror("pthread_mutex_init");
		return -1;
	}
	//创建线程
	pthread_t tid1;
	pthread_t tid2;
	pthread_t tid3;

	if(pthread_create(&tid1,NULL,callA,NULL) != 0)
	{
		perror("pthread_create");
		return -1;
	}
	if(pthread_create(&tid2,NULL,callB,NULL) != 0)
	{
		perror("pthread_create");
		return -1;
	}
	if(pthread_create(&tid3,NULL,callC,NULL) != 0)
	{
		perror("pthread_create");
		return -1;
	}

	pthread_join(tid1,NULL);
	pthread_join(tid2,NULL);
	pthread_join(tid3,NULL);
	pthread_mutex_destroy(&mutex);
	pthread_cond_destroy(&cond0);
	pthread_cond_destroy(&cond1);
	pthread_cond_destroy(&cond2);

	return 0;
}

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值