04Linux下C语言锁的学习之条件变量配合锁实现生产者与消费者模型

04Linux下C语言锁的学习之条件变量配合锁实现生产者与消费者模型
概述:
生产者与消费者模型比较简单,就是生产者不断往一个共享队列(大小不断变化)中生产数据,消费者不断消费。由于是不断也就是轮询,为防止占用过高CPU所以需要使用条件变量,为防止队列中的数据混乱所以需要锁。条件变量不懂的去看我上一篇文章即可。锁大家基本都知道为什么要使用了吧。
1 消费者和生产者的代码基本步骤
2 代码实现
非常简单,这里就不多说了,看注释即可。
这里提一下生产者生产数据的时候是使用头插法,每次将生产的节点放到链表的第一位。而消费的时候也是消费头部先。
执行上面的结果:
我们分析一下红色框的数据。生产者生产了三个数据,由于头插法,所以链表内容为:head->850->836->759。而消费者也是先消费头部,所以消费者先消费了850,然后是836。与代码实现的内容一致。
3 总结
非常简单,我这里没什么好总结的感觉。