多线程按顺序执行各自任务

//ubuntu@ubuntu:pthread$ cat eg.c
#include <myhead.h>                     //自定义的头文件,包含程序所需的所有头文件
void* task(void* arg);
sem_t sem;                            //定义无名信号量
pthread_mutex_t mutex;                //定义锁
int main(int argc,   const char *argv[])
{

	pthread_mutex_init(&mutex,NULL);      //对锁初始化,第二个参数是线程属性
	sem_init(&sem,0,0);                   //初始化无名信号量,第二个参数为0表示线程内共享,非零在进程中共享
	int n;
	printf("请输入需要创建的线程个数:");
	scanf("%d",&n);
	pthread_t thread[n];                  //创建线程号
	for(int i=0;i<n;i++)
	{
		if(pthread_create(&thread[i],NULL,task,(void*)(long long)i)!=0)  //创建线程,执行线程体任务,传入局部变量i;
		{
			printf("thread1 create error\n");
			return -1;
		}
	}
	for(int i=0;i<n;i++)
	{
		pthread_join(thread[i],NULL);          //循环回收线程资源
	}
	sem_destroy(&sem);                         //回收无名信号量
	pthread_mutex_destroy(&mutex);             //回收锁资源
	return 0;
}
void* task(void* arg)                          //线程体函数
{
	while(1)                                  //循环线程进行打印
	{
		switch((long)arg)                      //通过传入参数决定执行任务,可继续添加线程任务(此时传入的arg不是指针,存放的是数据,无需*号)
		{
		case 0:
			pthread_mutex_lock(&mutex);
			printf("1\n");                     //线程thread[0]执行的任务
			sem_post(&sem);
			pthread_mutex_unlock(&mutex);
			sleep(1);                          //延时1秒,观察现象
			break;
		case 1:
			sem_wait(&sem);
			pthread_mutex_lock(&mutex);
			printf("2\n");                     //线程thread[1]执行的任务
			pthread_mutex_unlock(&mutex);
			break;
		}
	}
	exit(EXIT_SUCCESS);                       //正常退出线程
}

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值