Linux线程同步操作(线程同步之信号量,线程同步之互斥锁,线程同步之条件变量)_信号量和互斥锁搭配条件变量实现线程同步代码(1)

pthread_exit(NULL);

}

int main(void)
{
int ret = -1;
pthread_t th = -1;

sem_init(&sem, 0, 0);

ret = pthread_create(&th, NULL, func, NULL);
if (ret != 0)
{
	printf("pthread_create error.\n");
	exit(-1);
}

printf("输入一个字符串,以回车结束\n");
while (scanf("%s", buf))
{
	// 去比较用户输入的是不是end,如果是则退出,如果不是则继续		
	if (!strncmp(buf, "end", 3))
	{
		printf("程序结束\n");
		flag = 1;
		sem_post(&sem);	
		//exit(0);
		break;
	}
	
	// 主线程在收到用户收入的字符串,并且确认不是end后
	// 就去发信号激活子线程来计数。
	// 子线程被阻塞,主线程可以激活,这就是线程的同步问题。
	// 信号量就可以用来实现这个线程同步
	sem_post(&sem);	
}


// 回收子线程
printf("等待回收子线程\n");
ret = pthread_join(th, NULL);
if (ret != 0)
{
	printf("pthread_join error.\n");
	exit(-1);
}
printf("子线程回收成功\n");

sem_destroy(&sem);

return 0;

}


编译的时候加参数 -pthread。




---


**3.线程同步之互斥锁**


互斥锁和信号量的关系:**可以认为互斥锁是一种特殊的信号量。**


应用函数:  
 pthread\_mutex\_init ();


pthread\_mutex\_destroy ();


pthread\_mutex\_lock();


pthread\_mutex\_unlock();



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

char buf[200] = {0};
pthread_mutex_t mutex;
unsigned int flag = 0;

// 子线程程序,作用是统计buf中的字符个数并打印
void *func(void *arg)
{
// 子线程首先应该有个循环
// 循环中阻塞在等待主线程激活的时候,子线程被激活后就去获取buf中的字符
// 长度,然后打印;完成后再次被阻塞

//while (strncmp(buf, "end", 3) != 0)
sleep(1);
while (flag == 0)
{	
	pthread_mutex_lock(&mutex);
	printf("本次输入了%d个字符\n", strlen(buf));
	memset(buf, 0, sizeof(buf));
	pthread_mutex_unlock(&mutex);
	sleep(1);
}


pthread_exit(NULL);

}

int main(void)
{
int ret = -1;
pthread_t th = -1;

pthread_mutex_init(&mutex, NULL);

ret = pthread_create(&th, NULL, func, NULL);
if (ret != 0)
{
	printf("pthread_create error.\n");
	exit(-1);
}

printf("输入一个字符串,以回车结束\n");
while (1)
{
	pthread_mutex_lock(&mutex);
	scanf("%s", buf);
	pthread_mutex_unlock(&mutex);
	// 去比较用户输入的是不是end,如果是则退出,如果不是则继续		
	if (!strncmp(buf, "end", 3))
	{
		printf("程序结束\n");
		flag = 1;
		
		//exit(0);
		break;
	}
	sleep(1);
	// 主线程在收到用户收入的字符串,并且确认不是end后
	// 就去发信号激活子线程来计数。
	// 子线程被阻塞,主线程可以激活,这就是线程的同步问题。
	// 信号量就可以用来实现这个线程同步
}


// 回收子线程
printf("等待回收子线程\n");
ret = pthread_join(th, NULL);
if (ret != 0)
{
	printf("pthread_join error.\n");
	exit(-1);
}
printf("子线程回收成功\n");

pthread_mutex_destroy(&mutex);

return 0;

}





---


**4.线程同步之条件变量**


条件变量(cond)使在多线程程序中用来实现“等待--->唤醒”逻辑常用的方法,是进程间同步的一种机制。条件变量用来阻塞一个线程,直到条件满足被触发为止,通常情况下条件变量和互斥量同时使用。一般条件变量有两个状态:


(1)一个/多个线程为等待“条件变量的条件成立“而挂起;


(2)另一个线程在“条件变量条件成立时”通知其他线程。


**应用函数:**


pthread\_cond\_init();


pthread\_cond\_destroy();


pthread\_cond\_wait ();


pthread\_cond\_signal/pthread\_cond\_broadcast();



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

char buf[200] = {0};
pthread_mutex_t mutex;
pthread_cond_t cond;
unsigned int flag = 0;

// 子线程程序,作用是统计buf中的字符个数并打印
void *func(void *arg)
{
// 子线程首先应该有个循环
// 循环中阻塞在等待主线程激活的时候,子线程被激活后就去获取buf中的字符
// 长度,然后打印;完成后再次被阻塞

//while (strncmp(buf, "end", 3) != 0)
//sleep(1);
while (flag == 0)
{	
	pthread_mutex_lock(&mutex);
	pthread_cond_wait(&cond, &mutex);
	printf("本次输入了%d个字符\n", strlen(buf));
	memset(buf, 0, sizeof(buf));
	pthread_mutex_unlock(&mutex);
	//sleep(1);
}


pthread_exit(NULL);

}

int main(void)
{
int ret = -1;
pthread_t th = -1;

pthread_mutex_init(&mutex, NULL);
pthread_cond_init(&cond, NULL);

ret = pthread_create(&th, NULL, func, NULL);
if (ret != 0)
{
	printf("pthread_create error.\n");
	exit(-1);
}

printf("输入一个字符串,以回车结束\n");
while (1)
{
	//pthread_mutex_lock(&mutex);
	scanf("%s", buf);
	pthread_cond_signal(&cond);
	//pthread_mutex_unlock(&mutex);
	// 去比较用户输入的是不是end,如果是则退出,如果不是则继续		
	if (!strncmp(buf, "end", 3))
	{
		printf("程序结束\n");
		flag = 1;
		
		//exit(0);
		break;
	}
	//sleep(1);
	// 主线程在收到用户收入的字符串,并且确认不是end后
	// 就去发信号激活子线程来计数。
	// 子线程被阻塞,主线程可以激活,这就是线程的同步问题。
	// 信号量就可以用来实现这个线程同步
}


// 回收子线程

最后

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Java工程师,想要提升技能,往往是自己摸索成长,自己不成体系的自学效果低效漫长且无助。

因此收集整理了一份《2024年嵌入式&物联网开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

img

img

img

img

img

img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上嵌入式&物联网开发知识点,真正体系化!

如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!

由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新!!

.(img-oZF7sdM2-1715585856481)]

[外链图片转存中…(img-YWGYjUOA-1715585856482)]

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上嵌入式&物联网开发知识点,真正体系化!

如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!

由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新!!

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值