当前位置:  技术问答>linux和unix

进程间互斥

    来源: 互联网  发布时间:2016-04-23

    本文导语:  可能情况有点特殊。 有个动态库,然后进程1和进程2(或者更多)都是链接到这个动态库。    进程1 进程2    。。。。     |             |        |    |-------|-----|--------|-            |      ...

可能情况有点特殊。
有个动态库,然后进程1和进程2(或者更多)都是链接到这个动态库。

   进程1 进程2    。。。。 

   |             |        |
   |-------|-----|--------|-
           |
       (动态库)

动态库里的某些函数 如api_ctrl(),
1)这个函数在进程1和进程2中是互斥的,不能被同时调用。
2)或者说api_ctrl是可以同时调用,只是该函数内的某些关键路径需要互斥。

现在的目标是:把互斥做在library里,进程1,进程2....进程N,不需要关心互斥的问题。

请大家发表高见,何种方法最佳(同时实现简单,效率高)。

|
也可以用mutex加共享内存,这样速度可能快一点,但复杂不少。

|
在共享内存中用semaphore或mutex进行同步就可以;如果需要大量调用且性能要求又高,是不是要思考下设计问题:为什么抛弃多进程的优点而利用多线程的缺点?

|


发表于:2008-11-04 11:07:144楼 得分:0 
文件锁啊, 
 


-------------------------
他的要求是函数已经都加载进去了,在调用时要互斥访问一个路径,这个路径,并不一定是文件,共享内存!!


互斥用锁,同步用信号量

感觉有点怪,



Mutex是一把钥匙,一个人拿了就可进入一个房间,出来的时候把钥匙交给队列的第一个。一般的用法是用于串行化对critical section代码的访问,保证这段代码不会被并行的运行。
Semaphore是一件可以容纳N人的房间,如果人不满就可以进去,如果人满了,就要等待有人出来。对于N=1的情况,称为binary semaphore。一般的用法是,用于限制对于某一资源的同时访问(互斥)。
Binary semaphore与Mutex的差异:
在有的系统中Binary semaphore与Mutex是没有差异的。在有的系统上,主要的差异是mutex一定要由获得锁的进程来释放。而semaphore可以由其它进程释放(这时的semaphore实际就是个原子的变量,大家可以加或减),因此semaphore可以用于进程间同步。Semaphore的同步功能是所有系统都支持的,而Mutex能否由其他进程释放则未定,因此建议mutex只用于保护critical section。而semaphore则用于保护某变量,或者同步。



|
使用信号量就可以了,可以根据函数内处理逻辑,只把处理'关键路径'的那一点代码放入临界区.

|
老大,文件锁不一定就是锁文件. 

对呀,二值信号量某种意义上可以说等效于信号量, 但一般来说锁就得由持有锁的进程来释放,而信号量做不到. 如果说锁完全跟信号量相等的话,何必还要锁? 另外一种情况是, 锁有不同的类型,递归锁,纠错锁, 自适应锁等, 可以适应你不同的需要,而你的直接用二值信号量并达不到要求.

|
文件锁啊,

|
个人觉得这样加锁有点“粗”,并发性可能会降不少

|
楼主看过W.Richard Stevens写的UNP Vol.II - Interprocess Communications的书吗?

|
互斥用锁,同步用信号量,看似没差别,其实差别还很大哦。


    
 
 

您可能感兴趣的文章:

  • 什么进程互斥量能随进程关闭自动销毁?
  • linux进程同步或互斥
  • 进程对串口读写时使用互斥机制吗?
  • 信号量可以用于多进程多线程同时互斥不?
  • 关于用文件实现进程互斥的问题
  • linux/unix里的进程互斥问题 ,有关lockf()函数!
  • 请教POSIX问题:一个进程中,可以有多个互斥锁麽?
  • 请问Unix下的进程互斥是用什么实现的?
  • 使用swap指令和Test and set指令设计一个解决N个进程互斥问题的算法
  • 请教高人:同一个套接字(做客户端)连接到server后在不同子进程里使用能否不采取互斥措施收发?
  • 使用TSL命令实现进程同步和互斥来防止竞争条件!
  • linux c进程互斥
  • c/c++ iis7站长之家
  • 进程互斥的问题
  • Unix下共享内存一个写N个读的进程同步与互斥
  • 进程的类型互斥量属性头文件问题
  • 问一个简单的进程同步/互斥的问题 [C 语言]
  • 寻求 Linux 进程互斥的方法,谢谢!
  • Unix进程互斥
  • 有了信号量以后,还要线程间的互斥锁,进程间的文件锁何用?
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • linux僵尸(zombie)进程介绍及清除
  • 进程Afork进程B,进程Bfor进程C,如果进程C退出发出SIGCHLD,A进程是否可以收到
  • Ubuntu查看内存,进程相关命令介绍
  • 如果一个server进程要fork许多子进程,但不等待子进程终止,也不希望子进程结束后处于僵进程状态直到父进程终止。请问可采用什么方法实现
  • linux下进程占用内存空间详解
  • 在多进程中父进程frok子进程,怎样让子进程自举,脱离父进程,而且父进程不退出
  • Linux进程的内核栈和用户栈概念,相互关系及切换过程
  • fock()开出的子进程的进程ID是否进程ID都大于父进程的?
  • android 4.0 托管进程介绍及优先级和回收机制
  • 父进程等待子进程n秒,如果子进程正常退出,父进程立即继续向下执行,如果子出现进程故障一直不退出,父进程等待n秒后继续向下执行,请问
  • linux下进程间通信:共享内存原理及具体用法举例(基于c/c++语言)
  • 多进程问题 子进程读取内容 读完挂起,父进程写 写入后唤醒子进程
  • 一个进程首先监听一个端口,等到有连接了就新开一个进程,让新进程来处理后面的通讯。请问母进程中已经打开了端口,子进程怎么来使用同一
  • 我在一个父进程中,生成了4个子进程,子进程的优先级是一样的。我现在想结束子进程。该如何做?
  • 子进程wait/waitpid//子进程不结束,父进程会等待子进程吗?
  • 在一个进程中我定义了几个全局变量,然后我又fork了几个子进程,子进程中是否可以各自对全局变量进行修改,如果各子进程都对其进行修改,
  • 怎样一次杀掉父进程创建的所有子进程?我在父进程中用kill(0,SIGKILL),结果父进程也给干掉了,参数0难道不是表示除自己外的所有同uid的进
  • 进程创建进程组后,然后创建该组中的进程,然后终止。这里的终止....?
  • 如何实现子进程根据父进程的信号来确定是否终止子进程???
  • 高手请教!linux怎样通过pid获取进程信息,如:进程名、进程状态等?
  • 如何通过进程号获得进程的一些信息,例如:进程运行的目录


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3