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

进程间共享的Posix mutex的锁定状态能否被子进程继承?

    来源: 互联网  发布时间:2017-04-11

    本文导语:  APUE中有这样一句话: "By inheriting a copy of the address space, the child also inherits the state of every mutex, readerwriter lock, and condition variable from the parent process." 说父进程中的mutex的锁定状态会被子进程继承,但是...

APUE中有这样一句话:
"By inheriting a copy of the address space, the child also inherits the state of every mutex, readerwriter lock, and condition variable from the parent process."

说父进程中的mutex的锁定状态会被子进程继承,但是没有提及具有进程间共享属性的mutex是否也遵守这一规则。
写了个小程序验证一下(程序中省略了错误检查)。
#include 
#include 
#include 
#include 
#include 
#include 
#include 

int main(void)
{
    pid_t pid;
    int   mid;
    int   bCreate = 0;      // 是否新建mutex
    key_t key = 0x12341234;

    pthread_mutex_t *mut;
    pthread_mutexattr_t attr;

    // shared memory
    mid = shmget(key, 0, 0);

    if( mid == -1 )         // 共享内存不存在,新建
    {
        bCreate = 1;
        mid = shmget(key, 64, IPC_CREAT | 0666);
    }
    mut = (pthread_mutex_t *) shmat(mid, 0, 0);

    if( bCreate == 1 )      // 初始化mutex,设置为进程间共享
    {
        pthread_mutexattr_init(&attr);
        pthread_mutexattr_setpshared(&attr, PTHREAD_PROCESS_SHARED);
        pthread_mutex_init(mut, &attr);
        pthread_mutexattr_destroy(&attr);
    }

    printf("lockn");
    pthread_mutex_lock(mut);

    printf("forkn");
    pid = fork();
    if( pid == 0 )          // 子进程无限期睡眠
    {
        while( 1 ) pause();
        exit(0);
    }

    printf("unlockn");
    pthread_mutex_unlock(mut);

    printf("lock againn");
    pthread_mutex_lock(mut);
    printf("overn");

    pthread_mutex_destroy(mut);
    kill(pid, SIGKILL);     // 杀死子进程
    return(0);
}


1、初次执行时,程序会创建共享内存,初始化mutex。结果是无停顿执行完毕。
   --看来父进程中的锁定状态没有被子进程继承,否则父进程的lock again不能完成。
2、再次执行时,程序阻塞在第一个lock的位置
   --UNP第二卷中,说“Posix mutex具有随进程的持续性”,看来也不适用于具有进程间共享属性的mutex

经验不足,不知道理解的对不对,求证一下。

|
是的,fork的时候复制整个内存空间,就会包括mutex, readerwriter lock, condition variable等线程间通讯的方式. 

|
  对于父子进程,pthread_mutex_lock返回值都是0,但是连续的调用pthread_mutex_lock(&mut),每次返回值也都是0,似乎在没有-lpthread选项的情况下,pthread_mutex_lock并没有起到作用。
  在没有-lpthread的情况下,似乎是通过semaphore实现mutex的,而pthread是利用futex实现mutex。

|
发现一点,就是当我不适用-lpthread选项去编译你上面的程序的时候,运行,父子进程都正常退出,而如果加上-lpthread,则子进程阻塞....

|
   “父进程中的mutex的锁定状态会被子进程继承”? 我在APUE的第八章看到的是“父进程设置的锁,子进程不继承”...
   "By inheriting a copy of the address space, the child also inherits the state of every mutex, readerwriter lock, and condition variable from the parent process."  不知道这句话是在书的哪一页?

|
里面说道的是文件锁。但是,互斥锁应该不会被继承。回去我也测试下。以前记得里面哪里有一句话说锁不会被继承。

|
第一次测试(使用你上面的代码):
jackson@jackson-desktop:~/桌面$ ./mut
lock
fork
child: lock
child: over

第二次测试(将pthread_mutex_lock改为pthread_mutex_trylock)
jackson@jackson-desktop:~/桌面$ g++ -o mut mutex.cpp -lpthread
jackson@jackson-desktop:~/桌面$ ./mut
lock
fork
child: lock
try lock errno:16
child try lock: Device or resource busy
child: over

最后一次测试(重新改为pthread_mutex_lock):
jackson@jackson-desktop:~/桌面$ g++ -o mut mutex.cpp -lpthread
jackson@jackson-desktop:~/桌面$ ./
lock
fork
child: lock

第一次测试和后两次测试结果居然不同,此后测试也都是子进程阻塞,迷糊了。。。。
机子重启之后,重新编译mut,按上面的流程测试,测试结果跟上面一样....

    
 
 
 
本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • linux僵尸(zombie)进程介绍及清除
  • 进程Afork进程B,进程Bfor进程C,如果进程C退出发出SIGCHLD,A进程是否可以收到
  • Ubuntu查看内存,进程相关命令介绍
  • 如果一个server进程要fork许多子进程,但不等待子进程终止,也不希望子进程结束后处于僵进程状态直到父进程终止。请问可采用什么方法实现
  • linux下进程占用内存空间详解
  • 在多进程中父进程frok子进程,怎样让子进程自举,脱离父进程,而且父进程不退出
  • docker中文入门学习手册 iis7站长之家
  • 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,