代码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个进程(包括父进程和子进程)