43.线程同步

看 2.cond代码

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

看代码3.cp

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

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

这样就可以互相唤醒了,

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

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

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

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

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

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

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

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

看课件代码吧,

相关推荐
唐青枫2 小时前
别再只会用 cron:Linux systemd Timer 定时任务实战详解
linux
大大大大晴天2 天前
Hudi Metadata Table 与 Hive Sync (HMS)怎么选?
大数据
AlfredZhao2 天前
生产环境里,为什么不建议把普通端口直接暴露到公网?
linux·https·443·80
手可摘星辰7772 天前
一次线上FlinkCDC异常排查复盘
大数据·flink
大大大大晴天2 天前
Hudi技术内幕:Metadata Table原理与实践
大数据
大大大大晴天3 天前
Hudi技术内幕:深入解析Index索引机制
大数据
戴为沐3 天前
Linux内存扩容指南
linux
阿里云大数据AI技术3 天前
Flink Forward Asia 2026 深圳启幕:Agentic Streaming for AI,开启实时智能新范式
大数据·flink
zylyehuo3 天前
Linux 彻底且安全地删除文件
linux
SelectDB4 天前
阶跃星辰基于 SelectDB 构建 PB 级 Agent 可观测平台
大数据·数据库·aigc