init进程接管孤儿进程的验证
#include <stdio.h> #include <unistd.h> #include <sys/types.h> #include<stdlib.h> #include<signal.h> int main(int argc , char **argv) {
int id;
id=fork();
if(id<0)
{
printf("fork error\n");
}
else if(id==0)
{
printf("I‘m in child process%d parent process%d\n",getpid(),getppid());
sleep(120);
exit(0);
}
else if(id>0)
{
printf("I‘m in parent process%d\n",getpid());
}
return 0;
}
[root@linux Desktop]# gcc 僵尸进程.c
[root@linux Desktop]# ./a.out
I‘m in parent process4308
[root@linux Desktop]# I‘m in child process4309 parent process 1
[root@linux Desktop]#
从上面的输出结果可以看出孩子进程4309的父进程是1号进程也就是init进程,这是因为子进程的父进程死亡后
子进程被init进程接管!所以说输出他的父进程号为1;
[root@linux Desktop]# ps --ppid 1
PID TTY TIME CMD
494 ? 00:00:00 udevd
1474 ? 00:00:00 vmware-vmblock-
1494 ? 00:00:20 vmtoolsd
1640 ? 00:00:00 portreserve
1647 ? 00:00:00 rsyslogd
1700 ? 00:00:02 dbus-daemon
1711 ? 00:00:00 NetworkManager
1717 ? 00:00:00 modem-manager
1723 ? 00:00:00 avahi-daemon
1733 ? 00:00:00 wpa_supplicant
1737 ? 00:00:00 cupsd
1762 ? 00:00:00 acpid
1771 ? 00:00:00 hald
1840 ? 00:00:00 sshd
1878 ? 00:00:00 tpvmlp
1951 ? 00:00:00 mysqld_safe
2113 ? 00:00:00 abrtd
2121 ? 00:00:00 abrt-dump-oops
2129 ? 00:00:01 crond
2140 ? 00:00:00 atd
2155 ? 00:00:00 rhsmcertd
2171 ? 00:00:00 gdm-binary
2178 tty2 00:00:00 mingetty
2180 tty3 00:00:00 mingetty
2182 tty4 00:00:00 mingetty
2190 tty5 00:00:00 mingetty
2192 tty6 00:00:00 mingetty
2229 ? 00:00:00 console-kit-dae
2299 ? 00:00:00 dbus-launch
2315 ? 00:00:00 devkit-power-da
2323 ? 00:00:00 auditd
2383 ? 00:00:00 polkitd
2389 ? 00:00:00 rtkit-daemon
2414 ? 00:00:00 gnome-keyring-d
2432 ? 00:00:00 dbus-launch
2433 ? 00:00:00 dbus-daemon
2447 ? 00:00:01 gconfd-2
2452 ? 00:00:20 gnome-settings-
2457 ? 00:00:00 seahorse-daemon
2462 ? 00:00:00 gvfsd
2468 ? 00:00:00 gvfs-fuse-daemo
2487 ? 00:00:00 bonobo-activati
2495 ? 00:00:13 wnck-applet
2496 ? 00:00:00 trashapplet
2499 ? 00:00:39 vmtoolsd
2503 ? 00:00:00 gvfs-gdu-volume
2510 ? 00:00:00 udisks-daemon
2516 ? 00:00:03 pulseaudio
2541 ? 00:00:00 gvfs-gphoto2-vo
2543 ? 00:00:01 gvfs-afc-volume
2555 ? 00:00:00 clock-applet
2556 ? 00:00:00 gdm-user-switch
2557 ? 00:00:00 gnote
2558 ? 00:00:00 notification-ar
2563 ? 00:00:00 restorecond
2566 ? 00:00:00 gvfsd-trash
2573 ? 00:00:12 gnome-screensav
2665 ? 00:00:00 gvfsd-burn
2677 ? 00:00:00 gvfsd-metadata
2706 ? 00:00:08 notification-da
2725 ? 00:00:44 gnome-terminal
2783 ? 00:00:44 gedit
4309 pts/0 00:00:00 a.out 注意下面这句没有输出
[root@linux Desktop]# ps --ppid 1
PID TTY TIME CMD
494 ? 00:00:00 udevd
1474 ? 00:00:00 vmware-vmblock-
1494 ? 00:00:20 vmtoolsd
1640 ? 00:00:00 portreserve
1647 ? 00:00:00 rsyslogd
1700 ? 00:00:02 dbus-daemon
1711 ? 00:00:00 NetworkManager
1717 ? 00:00:00 modem-manager
1723 ? 00:00:00 avahi-daemon
1733 ? 00:00:00 wpa_supplicant
1737 ? 00:00:00 cupsd
1762 ? 00:00:00 acpid
1771 ? 00:00:00 hald
1840 ? 00:00:00 sshd
1878 ? 00:00:00 tpvmlp
1951 ? 00:00:00 mysqld_safe
2113 ? 00:00:00 abrtd
2121 ? 00:00:00 abrt-dump-oops
2129 ? 00:00:01 crond
2140 ? 00:00:00 atd
2155 ? 00:00:00 rhsmcertd
2171 ? 00:00:00 gdm-binary
2178 tty2 00:00:00 mingetty
2180 tty3 00:00:00 mingetty
2182 tty4 00:00:00 mingetty
2190 tty5 00:00:00 mingetty
2192 tty6 00:00:00 mingetty
2229 ? 00:00:00 console-kit-dae
2299 ? 00:00:00 dbus-launch
2315 ? 00:00:00 devkit-power-da
2323 ? 00:00:00 auditd
2383 ? 00:00:00 polkitd
2389 ? 00:00:00 rtkit-daemon
2414 ? 00:00:00 gnome-keyring-d
2432 ? 00:00:00 dbus-launch
2433 ? 00:00:00 dbus-daemon
2447 ? 00:00:01 gconfd-2
2452 ? 00:00:20 gnome-settings-
2457 ? 00:00:00 seahorse-daemon
2462 ? 00:00:00 gvfsd
2468 ? 00:00:00 gvfs-fuse-daemo
2487 ? 00:00:00 bonobo-activati
2495 ? 00:00:13 wnck-applet
2496 ? 00:00:00 trashapplet
2499 ? 00:00:39 vmtoolsd
2503 ? 00:00:00 gvfs-gdu-volume
2510 ? 00:00:00 udisks-daemon
2516 ? 00:00:03 pulseaudio
2541 ? 00:00:00 gvfs-gphoto2-vo
2543 ? 00:00:01 gvfs-afc-volume
2555 ? 00:00:00 clock-applet
2556 ? 00:00:00 gdm-user-switch
2557 ? 00:00:00 gnote
2558 ? 00:00:00 notification-ar
2563 ? 00:00:00 restorecond
2566 ? 00:00:00 gvfsd-trash
2573 ? 00:00:12 gnome-screensav
2665 ? 00:00:00 gvfsd-burn
2677 ? 00:00:00 gvfsd-metadata
2706 ? 00:00:08 notification-da
2725 ? 00:00:44 gnome-terminal
2783 ? 00:00:44 gedit
[root@linux Desktop]#
在我测试这两幅图的时候,第一幅图输出后,要等大概两分多钟,也就是大概子进程执行完后,
init进程调用wait会清理掉刚才接收的子进程(4309 )。
子进程4309
//如果将signal(SIGCHLD, SIG_IGN);这行代码加上放在main函数的第一行,应该说会出现一种情况当父进程退出时,父进程的父进程不会理会他,而直接让init进程接管他,但是用ps --ppid 1输出时,没有发现父进程。!只有子进程号!
郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。