Linux系统fork()函数简析
fork()函数的作用就是创建一个一模一样的进程,当这个程序执行到fork()函数时,通过系统调用会创建一个与主进程一样的子进程。意思就是两个进程可以做一样的事,做两遍。
#include <cstdio>
#include <unistd.h>
#include <stdio.h>
int main()
{
pid_t mypid; //定义一个变量,用来保存fork()函数执行后的返回值
int Number = 0;
mypid = fork(); //创建子进程,复制给mypid
if (mypid<0) //用mypid的值,判断是否为主进程
{
printf("error in fork\n");
}
else if(fpid==0)
{
printf("i am A %d\n", getpid());
Number++;
}
else
{
printf("i am B %d\n", getpid());
Number++;
}
sleep(1000);
return 0;
}
利用fork()函数创建进程后返回值赋予mypid,如果
1,在父进程中,fork返回新创建子进程的进程ID;
2,在子进程中,fork返回0;
3,如果出现错误,fork返回一个负值;
所以,判断mypid的值就能知道是否是主进程。getpid()函数的作用是获得当前进程的ID。
(注:printf()函数字符串后面要加\n,换行符,否则可能出现不打印到控制台窗口的情况。具体原因暂不谈)
运行结果为:
后面是进程ID,不同电脑不一样。
我们看到一个if判断执行了两次,而且是不一样的结果。这就是因为利用fork()函数创建主子进程的原因。
那如果在for循环里面用fork()会怎么样。
#include <cstdio>
#include <unistd.h>
#include <stdio.h>
int main()
{
pid_t mypid;
int checknumber = 0;
for (int i = 0; i < 2; i++)
{
mypid = fork();
if (mypid == 0)
{
printf("It's child.%d\n", checknumber);
checknumber++;
}
else
{
printf("It's father.%d\n", checknumber);
checknumber++;
}
}
sleep(1);
return 0;
}
运行结果为:
我们看到有六次输出,主子进程各三个,其实这也可以看成链表的形式,我们可以用树来表示就清楚很多:
(图片摘自https://blog.csdn.net/jason314/article/details/5640969)
且当主进程结束后,就是for循环结束后,程序执行到return 0,程序就结束了,所一子进程无法进入第三次循环,没有父进程的子进程是不允许操作的。
如果想更深入了解,请移步https://blog.csdn.net/jason314/article/details/5640969
谢谢!