linux进程间的通信(C): 使用信号量进行同步的共享内存机制
一、简介
共享内存为在多个进程之间共享和传递数据提供了一种有效的方式。
但它本身并未提供同步机制。
在实际编程中,可以使用
信号量,
传递消息(使用管道或IPC消息),
生成信号,
条件变量,
等方法来提供读写之间的有效的同步机制。
本例程序使用信号量进行同步,
主要是因为它方便,使用广泛,且独立于进程。
本例程序实现了,
生产者进程:
每次读取YUV输入文件的一帧,
然后将其写到共享内存中。
消费者进程:
每次从共享内存中读到一帧,
处理后,
将其写到输出文件。
两个进程间使用信号量来保证同步处理每一帧。
本例程序很好地示范了共享内存和信号量的机制,
对于实际程序的开发很有意义。
二、生产者进程
common.h
用来设置一些测试用的基本参数。
- /*
- * \File
- * common.h
- */
- #ifndef __COMMON_H__
- #define __COMMON_H__
免责声明: 本文仅代表作者个人观点,与爱易网无关。其原创性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容、文字的真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。