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
" ) ;  
          sleep(10);  
            
        printf ( "parent exit
" ) ;  
        exit ( 0 ) ;  
     }  
       
     printf ( "child begin
" ) ;  
     sleep(100);  
       
     printf ( "child exit
" ) ;  
     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
" ) ;  
          sleep(10);  
            
        printf ( "parent exit
" ) ;  
        exit ( 0 ) ;  
     }  
       
     setsid();
     printf ( "child begin
" ) ;  
     sleep(100);  
       
     printf ( "child exit
" ) ;  
     return 0 ;  
}  

重新启动应用:

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

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

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

原文地址:https://www.cnblogs.com/LiuYanYGZ/p/14201983.html