int main()
{
printf("abc\n");
pid_t r = fork();//子进程从fork()的下条语句开始运行,标准答案是从fork的后半部分开始运行
if(r==0)
{
printf("getpid = %d\n",getpid());
printf("getppid = %d\n",getppid());

}

if(r>0)
{
printf("r = %d\n",r);
printf("getpid = %d\n",getpid());
printf("getppid = %d\n",getppid());

}
if(r==-1)
{
printf("error!\n");
}
printf("123\n");


./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?
因为文本为全缓冲,而屏幕为行缓冲,当将执行程序的结果直接输出到屏幕时,遇到‘\n’,将结果
强制刷新,输出到屏幕,然后将内容清空,所以父进程拷贝到子进程的代码中不含有abc,
但输出到文本不一样,文本为全缓冲,系统会将代码全缓冲到一个缓冲区中,父进程执行代码printf
("abc\n")后,并不会将其清空,而是将其存放到缓冲区,并copy到子进程,然后子进程运行后就会再次输出
abc。

 

相关文章:

  • 2022-12-23
  • 2022-12-23
  • 2021-12-05
  • 2022-12-23
  • 2022-03-03
  • 2022-12-23
猜你喜欢
  • 2022-12-23
  • 2021-07-09
  • 2021-10-24
  • 2022-12-23
  • 2022-01-24
  • 2022-12-23
  • 2021-12-25
相关资源
相似解决方案