今天在測試 APUE 對殭屍進程採用兩個 fork 的技巧手段。
其代碼是這樣的:
#include "apue.h"
#include <sys/wait.h>
int main(void) {
printf("father pid = %ld\n", (long)getpid());
pid_t pid;
if((pid = fork()) < 0) {
err_sys("fork error");
} else if(pid == 0) {
if((pid = fork()) < 0)
err_sys("fork error");
else if(pid > 0) {
printf("first child pid = %ld , parent pid = %ld\n", (long)getpid(),(long) getppid());
exit(0); // 直接結束 first child
}
// now is second child
printf("before sleep: second child pid = %ld, parent pid = %ld\n", (long)getpid(),(long)getppid());
sleep(3);
printf("after sleep: second child pid = %ld, parent pid = %ld\n", (long)getpid(),(long)getppid());
exit(0);
}
if(waitpid(pid, NULL, 0) != pid) // wait for first child
err_sys("waitpid error");
exit(0);
}
ps:中間很多 printf 都是我自己加的。
然後在終端運行:
hjm@hjm-Inspiron:~/InterviewPreparation/apue/Examples/8-8$ ./8-8
father pid = 3984
first child pid = 3985 , parent pid = 3984
before sleep: second child pid = 3986, parent pid = 3985
after sleep: second child pid = 3986, parent pid = 1522
發現和書上的輸出不大一樣,重複測試了幾次,在 after sleep 之後的 parent pid 都是 1522.
書上不是說,父進程先於子進程結束,子進程會被 init 收養嗎,其 parent pid 應該是 1 纔對啊。
---------解決-------------
搜到了一篇博客,提到:當用圖形界面時,不會是 init 收養。
然後就聽了博客上的,按 ctrl+alt+f1 進入了字符界面:
然後就是這樣,什麼也輸入不了,聽網上的按 ctrl + alt + f7 也沒用。。。我一度以爲是卡了,然後等了一會,就強制重啓了。
重啓後甚是不甘,再試了試,還是這樣。。。
然後就臉滾鍵盤,按到了 ctrl+alt+f3,進入了 tty3:
試過了,可以用。也確實,運行了 8-8 程序,這此情況下,after sleep 後的 parent pid = 1
然後 ctrl+alt+f4 進入了 tty4,然後 tty5,tty6
最後按 ctrl+alt+f7,依舊不能退回圖形界面,
然後 ctrl+alt+f2,居然回到了圖形界面。。。。。網上不是說是 ctrl+alt+f7 嗎????? wtf ??