看 2.cond代码
生产者和消费者 是互斥关系保证数据安全。建个群通知就是同步
看代码3.cp

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

作为消费者,pop数据后这个队列一定不为满,此时如果生产者休眠大于0,唤醒,如果生产者0,那说明一直在push,不用唤醒
这样就可以互相唤醒了,
如果都不放if,生产完直接唤醒消费者,消费完唤醒生产者,唤醒操作放在解锁之前还是之后,
若在前生产完了唤醒消费者,消费者能醒来,申请锁失败,但是不是在条件变量等而是去锁等,解锁重新持有锁。就可以返回了,所以可以放锁前面。
后面的话,万一锁被其他人拿走,在锁等待,到时候也能拿到锁,都行。放锁前可以、

1.万一休眠失败,没进入休眠,还push,多插数据了
2.多生产单消费,消费一个,broad唤醒全部呢,此时第一个生产者填了一个空,剩下也填这样多填了
用while二次 检测,走到下面才能确定一定有空间有数据
每个线程都可以从队列拿到对应任务串行,但是线程是并发处理这个任务,此时生产者可以从另一个模块继续获取任务,这是生产消费模型,获取处理任务才是最耗时的
一把锁,本就是多生产多消费,不需要再改代码
看课件代码吧,