int main()
{
printf("abc
");
pid_t r = fork();//子进程从fork()的下条语句开始运行,标准答案是从fork的后半部分开始运行
if(r==0)
{
printf("getpid = %d
",getpid());
printf("getppid = %d
",getppid());
}
if(r>0)
{
printf("r = %d
",r);
printf("getpid = %d
",getpid());
printf("getppid = %d
",getppid());
}
if(r==-1)
{
printf("error!
");
}
printf("123
");
./getpid > 1.txt
1.txt:
abc
r = 2925
getpid = 2924
getppid = 2349
123
abc
getpid = 2925
getppid = 1
123
./getpid
abc
r = 2922 创建的子进程的pid
getpid = 2921 当前进程的pid
getppid = 2349当前进程父进程的pid
123
gec@ubuntu:~/shared$ getpid = 2922当前进程的pid
getppid = 1 //init进程号,父进程死了找了一个继父init,如果用else if else,结果会不一样。
123
为什么1.txt多个abc?
因为文本为全缓冲,而屏幕为行缓冲,当将执行程序的结果直接输出到屏幕时,遇到‘
’,将结果
强制刷新,输出到屏幕,然后将内容清空,所以父进程拷贝到子进程的代码中不含有abc,
但输出到文本不一样,文本为全缓冲,系统会将代码全缓冲到一个缓冲区中,父进程执行代码printf
("abc
")后,并不会将其清空,而是将其存放到缓冲区,并copy到子进程,然后子进程运行后就会再次输出
abc。