+ -
当前位置:首页 → 问答吧 → Unix下共享内存一个写N个读的进程同步与互斥

Unix下共享内存一个写N个读的进程同步与互斥

时间:2011-06-29

来源:互联网

Unix下写了一个类:
1,申请共享内存作为数据存储区
2,提供了insert接口和find接口,insert往里面插入数据,find查找数据(不改写数据)
3,要实现多线程/进程可以同时find,但是同一时间只能有一个进程/线程insert,find的时候不能insert,insert的时候也不能find

网上找了一些资料,有说用信号量做,但是find是没有上限的,也不消耗什么资源,这里的insert和find并不是生产者-消费者模式

也有说用文件锁来做,但是锁的话,也是只能一时间只有一个insert,也只能有一个find,和二值信号量没什么区别

拜求高人要怎么解决。

作者: The_Only_Name_2   发布时间: 2011-06-29

google linux读写锁

作者: thefirstz   发布时间: 2011-06-29

像这样读的进程比较多的话,用读写锁是很不错的方法。
就上楼上说的----------

更多技术文章敬请关注:武汉华嵌-嵌入式培训专家,国内领先的嵌入式服务机构,

http://www.embedhq.org

作者: u_buntu   发布时间: 2011-06-29