43.线程同步

看 2.cond代码

生产者和消费者 是互斥关系保证数据安全。建个群通知就是同步

看代码3.cp

生产了个数据 此时发现当前消费者在休眠,唤醒消费者,如果消费者没休眠,那么消费者就pop,就不需要唤醒

作为消费者,pop数据后这个队列一定不为满,此时如果生产者休眠大于0,唤醒,如果生产者0,那说明一直在push,不用唤醒

这样就可以互相唤醒了,

如果都不放if,生产完直接唤醒消费者,消费完唤醒生产者,唤醒操作放在解锁之前还是之后,

若在前生产完了唤醒消费者,消费者能醒来,申请锁失败,但是不是在条件变量等而是去锁等,解锁重新持有锁。就可以返回了,所以可以放锁前面。

后面的话,万一锁被其他人拿走,在锁等待,到时候也能拿到锁,都行。放锁前可以、

1.万一休眠失败,没进入休眠,还push,多插数据了

2.多生产单消费,消费一个,broad唤醒全部呢,此时第一个生产者填了一个空,剩下也填这样多填了

用while二次 检测,走到下面才能确定一定有空间有数据

每个线程都可以从队列拿到对应任务串行,但是线程是并发处理这个任务,此时生产者可以从另一个模块继续获取任务,这是生产消费模型,获取处理任务才是最耗时的

一把锁,本就是多生产多消费,不需要再改代码

看课件代码吧,

相关推荐
只说证事2 小时前
CDA数据分析师适合在校生吗?什么时候准备更划算
大数据
charlie1145141912 小时前
嵌入式Linux驱动开发指南02——内核空间基础与硬件访问
linux·运维·c语言·驱动开发·嵌入式硬件
zzzsde2 小时前
【Linux】进程信号(1)理解信号及信号产生的方式
linux·运维·服务器·算法
DBA大董2 小时前
TDengine3.x 数据文件详解
大数据·linux·时序数据库·dba·tdengine
csgo打的菜又爱玩3 小时前
5.HeartbeatServices启动解析.md
大数据·flink·源代码管理
老神在在0013 小时前
商城系统(Mall)性能测试实战:从脚本搭建到结果分析
大数据·测试工具·jmeter·压力测试
生万千欢喜心3 小时前
Linux 安装金蝶天燕中间件 AAS-V9.0.zip
java·linux
aq55356003 小时前
三大Linux系统终极对决
linux·运维·服务器
亚马逊云开发者3 小时前
【Bedrock AgentCore】Multi-Agent 架构实战:用 6 个 Agent 打通零售供应链数据→洞察→行动全链路
大数据·架构·零售