1. fork()函数
通过系统调用创建一个与原来进程几乎完全相同的进程,这个新的进程就成为子进程。一个进程调用fork()函数以后,系统先给新的进程分配资源,例如存储数据可代码空间。然后把原来进程的值都复制到新的进程当中,只有少数值与原来不同。
调用fork()函数之后,fork()之后的代码一定是两个进程同时执行,而之前的代码已经由父进程执行完毕。
for()函数返回值:返回一个大于0的值给父进程,返回0给子进程,返回其他值说明fork()失败。
#include<unistd.h>
#include<stdio.h>
int main()
{
//--1.Create child_process 1
int pid_child1 = fork();
//--2.print father_process id
if(pid_child1==0)
printf("father_process id is:%d\n",getpid());
//--3.Create child_process 2
else if(pid_child1>0)
{
//--(1)Create child_process 2
int pid_child2 = fork();
//--(2)print child_process 1 id
if(pid_child2==0)
printf("child_process 1 id is:%d\n",getpid());
//--(3)print child_process 1 id
else if(pid_child2>0)
printf("child2_process 2 id is:%d\n",getpid());
//--(4)error
else
printf("error in create child_process 2!\n");
}
//--4.error
else
printf("error in create child_process 1!\n");
//--5.return
return 0;
}这段之中,结果如下
可以看到 pid==0和pid>0都得到了执行,这是为什么?理论上不应该都只是执行一个么?对了,这是因为同时有两个进程在执行,所以,是并发执行for()之后的代码部分。当然上述代码有个小问题,不知道你有没有发现,如果发现了欢迎留言。
本文详细解析了Linux中的fork()函数,该函数通过系统调用来创建一个与父进程几乎完全相同的子进程。在调用fork()后,新进程会复制父进程的大部分状态,但返回值区分了父进程和子进程:大于0的值给父进程,0给子进程,其他值表示失败。因此,fork()之后的代码段在父进程和子进程中并发执行。

1965

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



