/* 创建孤儿进程 父进程终止后,向子进程发送挂断信号,又接着发送继续信号。 */ #include <stdio.h> #include <stdlib.h> #include <string.h> #include <errno.h> #include <signal.h> #include <sys/types.h> #include <unistd.h> /* 处理接受到的挂断信号 */ static void sig_hup(int signo) { printf("SIGHUP recvived, pid = %d \n", getpid()); } /* 打印进程ID、父进程ID、进程组ID、前台进程组ID */ static void pr_ids(char* name) { printf("%s: pid = %d, ppid = %d, pgrp = %d, tpgrp = %d \n", name, getpid(), getppid(), getpgrp(), tcgetpgrp(STDIN_FILENO)); fflush(stdout); } int main( int agrc, char* argv[]) { char c; pid_t pid; pr_ids("parent"); // 打印主进程(父进程)信息 if ((pid = fork()) < 0) { printf("fork error\n"); exit(-1); } else if( pid > 0) /* parent */ {// 在父进程中 sleep(5); exit(0); } else /* child */ {// 在子进程中 pr_ids("child"); signal(SIGHUP, sig_hup); // 绑定挂断信号 kill(getpid(), SIGTSTP); // 向自己发送停止信号(Ctrl+Z),暂停进程 pr_ids("child"); if (read(STDIN_FILENO, &c, 1) != 1) { printf("read error from controlling TTY, errno = %d\n", errno); } exit(0); } return 0; }
运行结果:
huangcheng@ubuntu:~$ ./a.out parent: pid = 3569, ppid = 2135, pgrp = 3569, tpgrp = 3569 child: pid = 3570, ppid = 3569, pgrp = 3569, tpgrp = 3569 SIGHUP recvived, pid = 3570 child: pid = 3570, ppid = 1, pgrp = 3569, tpgrp = 3569