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后子进程不受终端影响,终端退出,不影响子进程