代码1:
#include <stdio.h>
int main()
{
int i=0;
int j=0;
for(i=0; i< 3; i++)
{
int id = fork();
if(id == 0)
{
printf("i am child:%d\n",j);
}
else
{
j++;
printf("i am father:%d\n",j);
}
}
sleep(2);
return 0;
}
结果:
分析:因为每一个child和father都有自己的进程地址空间,所以就会每一个地址空间中都有自己的i,j,所以就是这种结果
代码2:
#include<stdio.h>
#include<unistd.h>
#include<sys/types.h>
int main()
{
int i=0;
for(i=0; i<2; i++)
{
fork();
//printf("-");
printf("-\n");
}
wait(NULL);
wait(NULL);
return 0;
}
结果:
代码3:
#include<stdio.h>
#include<unistd.h>
#include<sys/types.h>
int main()
{
int i=0;
for(i=0; i<2; i++)
{
fork();
printf("ppid:%d pid:%d i=%d \n",getppid(),getpid(),i);
}
sleep(2);
return 0;
}运行结果:
有pid可知:最后其实是产生出来了4个进程(包括父进程和子进程)
本文通过三个C语言程序实例,详细解析了fork()函数在进程创建中的应用,展示了父子进程间的独立性和交互方式。
多次之后父子进程的数目变化&spm=1001.2101.3001.5002&articleId=52042278&d=1&t=3&u=dff42a9fd0534ad68d3bb4dd2f09e018)
1807

被折叠的 条评论
为什么被折叠?



