百度了一圈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 ) ;
}
<span style="color:#ff0000;">setsid();</span>
printf ( "child begin\n" ) ;
sleep(100);
printf ( "child exit\n" ) ;
return 0 ;
}
重新启动应用:
查看进程,testSetSid分为两个进程组:
关闭运行testSetSid的终端窗口,查看进程,父进程退出,子进程继续存在:
说明:setsid后子进程不受终端影响,终端退出,不影响子进程