fork()函数
关于fork()函数的几个例题
我们都知道fork()一次调用两次返回,当fork()函数被调用的时候,父进程把代码和数据复制给子进程
#include <stdio.h>
#include <sys/types.h>
#include <unistd.h>
int main(void){
int i;
for(i=0;i<2;i++){
fork();
printf("*\n");
}
return 0;
}
此时画进程图可以得知,显然是有6颗*
#include <stdio.h>
#include <sys/types.h>
#include <unistd.h>
int main(void){
int i;
for(i=0;i<2;i++){
fork();
printf("*");
}
return 0;
}
而这种情况时,打眼看过去也许会以为和上一个程序没有什么差别,但实际上运行结果是8颗星,(注意,前面有两颗)
但是这究竟是为什么那?
实际上,这是因为当父进程fork的时候会将堆栈,缓冲区内的数据都复制给子进程,而\n是可以清空缓冲区的,但是单纯的printf("");会将缓冲区内的也传给子进程,那么下一次printf的时候就会输出两颗星。
下面手画一个图描述一下,略丑,勿喷。
下面一个题:
今天的重头戏
代码如下:
int main(int argc,char *argv[])
{
fork();
fork()&&fork()||fork();
//A&&B||C
//如A是假,B跳过;A为真,B执行,(A&&B)为真
fork();
}
首先要知道c语言的短路现象,(java就不是短路现象,&&和||两边的操作数无论如何都会进行计算)
A&&B||C
如A是假,B跳过;A为真,B执行,(A&&B)为真
同时知道fork()的返回值
1)在父进程中,fork返回新创建子进程的进程ID;
2)在子进程中,fork返回0;
3)如果出现错误,fork返回一个负值;
网上有很多解释,但我没有看,这里给出我自己的解法:
首先,把5个fork()函数分别标记为①②③④⑤,用来相互区别,然后直接进行算结果
注意这个代码的运行结果有20个*,而题目讲的是产生的新进程的话,是19个进程,结果如下
下面依然是手画的图,略丑,勿喷;
图只画了下面的那一部分,上面的那部分也一样,最后算新进程的一共有19个即,10*2-1;
至于问为啥不花全,别问,问就是懒。重度懒癌患者加巨忙。