setsid的作用

摘自:https://blog.csdn.net/sweetfather/article/details/79457261

百度了一圈setsid的作用,基本都是一个抄袭一个,真的是太桑心,引用百度百科原话:

当进程是会话的领头进程时setsid()调用失败并返回(-1)。
setsid()调用成功后,返回新的会话的ID,调用setsid函数的进程成为新的会话的领头进程,并与其父进程的会话组和进程组脱离。
由于会话对控制终端的独占性,进程同时与控制终端脱离。

 

这段解释比较费解,用代码说明:

#include <sys/file.h>  
#include <stdio.h>  
#include <unistd.h>  
#include <stdlib.h>  
#include <sys/file.h>  
                                          
int main (int argc, char ** argv)  
{  
     if ( fork() > 0 ) {  
          printf ( "parent begin\n" ) ;  
          sleep(10);  
            
        printf ( "parent exit\n" ) ;  
        exit ( 0 ) ;  
     }  
       
     printf ( "child begin\n" ) ;  
     sleep(100);  
       
     printf ( "child exit\n" ) ;  
     return 0 ;  
}  

 

上面这段代码,运行时父进程等待10s,子进程等待100s

应用启动:

 

打开另外一个终端窗口,查看进程存在,testSetSid同在一个进程组:

 

关闭运行testSetSid的终端运行窗口,再查看进程,进程组退出,父子进程都已不在:

 

 

 

说明:父子进程都受终端影响,终端退出,父子进程也会退出

 

 ===================================================

 

如果我们在子进程开始时调用setsid():

#include <sys/file.h>  
#include <stdio.h>  
#include <unistd.h>  
#include <stdlib.h>  
#include <sys/file.h>  
                                          
int main (int argc, char ** argv)  
{  
     if ( fork() > 0 ) {  
          printf ( "parent begin\n" ) ;  
          sleep(10);  
            
        printf ( "parent exit\n" ) ;  
        exit ( 0 ) ;  
     }  
       
     setsid();
     printf ( "child begin\n" ) ;  
     sleep(100);  
       
     printf ( "child exit\n" ) ;  
     return 0 ;  
}  

 

重新启动应用:

 

 

查看进程,testSetSid分为两个进程组:

 

 

关闭运行testSetSid的终端窗口,查看进程,父进程退出,子进程继续存在:

 

说明:setsid后子进程不受终端影响,终端退出,不影响子进程

posted @ 2020-12-28 15:49  LiuYanYGZ  阅读(725)  评论(0编辑  收藏  举报