当前位置: 技术问答>linux和unix
Unix下共享内存一个写N个读的进程同步与互斥
来源: 互联网 发布时间:2016-12-26
本文导语: Unix下写了一个类: 1,申请共享内存作为数据存储区 2,提供了insert接口和find接口,insert往里面插入数据,find查找数据(不改写数据) 3,要实现多线程/进程可以同时find,但是同一时间只能有一个进程/线程insert,fin...
Unix下写了一个类:
1,申请共享内存作为数据存储区
2,提供了insert接口和find接口,insert往里面插入数据,find查找数据(不改写数据)
3,要实现多线程/进程可以同时find,但是同一时间只能有一个进程/线程insert,find的时候不能insert,insert的时候也不能find
网上找了一些资料,有说用信号量做,但是find是没有上限的,也不消耗什么资源,这里的insert和find并不是生产者-消费者模式
也有说用文件锁来做,但是锁的话,也是只能一时间只有一个insert,也只能有一个find,和二值信号量没什么区别
拜求高人要怎么解决。
1,申请共享内存作为数据存储区
2,提供了insert接口和find接口,insert往里面插入数据,find查找数据(不改写数据)
3,要实现多线程/进程可以同时find,但是同一时间只能有一个进程/线程insert,find的时候不能insert,insert的时候也不能find
网上找了一些资料,有说用信号量做,但是find是没有上限的,也不消耗什么资源,这里的insert和find并不是生产者-消费者模式
也有说用文件锁来做,但是锁的话,也是只能一时间只有一个insert,也只能有一个find,和二值信号量没什么区别
拜求高人要怎么解决。
|
读写锁支持进程间共享的,设置属性
pthread_rwlockattr_setpshared
或者可以使用fcntl()文件锁,支持读锁F_RDLCK,与写锁F_WRLCK
pthread_rwlockattr_setpshared
或者可以使用fcntl()文件锁,支持读锁F_RDLCK,与写锁F_WRLCK
|
文件锁也分为读锁和写锁,find的时候加读锁,insert加写锁。。。
|
可惜读写锁没法进程间共享.
我记得UNIX书上有自己实现的读写锁,回去给你找下.
我记得UNIX书上有自己实现的读写锁,回去给你找下.
|
google linux读写锁
|