3、P中fork()语句启动子进程Q,并将Q的PID返回,而Q中的fork()语句不启动新进程,仅将0返回。
#include <unistd.h>
#include <sys/types.h>
main ()
{
pid_t pid;
printf(“hello!\n”);
pid=fork();
if (pid < 0)
printf(“error in fork!”);
else if (pid == 0)
printf("i am the child process, my process id is %d\n ",getpid());
else
printf(“i am the parent process, my process id is %d\n”,getpid());
printf(“bye!\n”);
}
这里可以看出parent process执行了printf(“hello!\n”); 而child process 没有执行printf(“hello!\n”);
有一个让人很迷惑的例子:
#include <unistd.h>
#include <sys/types.h>
main ()
{
pid_t pid;
printf(“fork!”); //printf(“fork!\n”)
pid=fork();
if (pid < 0)
printf(“error in fork!\n”);
else if (pid == 0)
printf(“i am the child process, my process id is %d\n”,getpid());
else
printf(“i am the parent process, my process id is %d\n”,getpid());
}
此时打印输出了两个fork!这不免让人以为是child process从#include处开始执行,所以也执行了printf(“fork!”); 语句。
其实不然,出现这种问题的原因在于:
这就跟Printf的缓冲机制有关了,printf某些内容时,操作系统仅仅是把该内容放到了stdout的缓冲队列里了,并没有实际的写到屏幕上 。但是,只要看到有\n, 则会立即刷新stdout,因此就马上能够打印了.
mian函数(parent process)运行了printf(“fork!”) 后, "fork!“仅仅被放到了缓冲里,再运行到fork时,缓冲里面的 AAAAAA 被子进程(child process)继承了,因此在子进程度stdout缓冲里面就也有了"fork!”。所以,你最终看到的会是 “fork!” 被printf了2次!!!
而mian函数(parent process)运行 printf(“fork!\n”)后,“fork!” 被立即打印到了屏幕上,之后fork到的子进程(child process)里的stdout缓冲里不会有"fork!“内容 因此你看到的结果会是"fork!” 被printf了1次!!!
先自我介绍一下,小编浙江大学毕业,去过华为、字节跳动等大厂,目前在阿里
深知大多数程序员,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年最新Linux运维全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上运维知识点,真正体系化!
由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新
并且后续会持续更新**