对fork函数的理解

//--------------------------------------------------------begin
int pid=fork();
if(pid < 0){
//失败,一般是该用户的进程数达到限制或者内存被用光了
........
}
else if(pid == 0){
//子进程执行的代码
......
}
else{
//父进程执行的代码
.........
}
.........
//-------------------------------------------------------end

对fork函数的疑惑:

对于上面一段代码,刚开始读的时候,不能理解的是执行一次fork,为什么if和elseif语句都会执行。

对fork函数疑惑的解决:

http://binux.blog.51cto.com/742827/163234通过这个网址和课本上的介绍,最后自己想明白了。

fork函数的调用会有两种情况:

如果函数调用失败时,它会返回-1,直接运行else的可能;

如果函数调用成功的话,它会分裂成两个进程,所谓的分裂成两个进程,指的是创建一个新的进程,也就是子进程。在fork函数调用时,将进行从父进程虚空间到子进程虚空间的拷贝,两个进程的代码段和用户数据段是完全相同的,并且两个进程的系统数据段也是相同的。然后两个进程同时进行,父进程fork函数返回子进程的pid,子进程返回0.

子进程,因为可以通过getpid() 和getppid()获取自己的进程和父进程的pid; 父进程中,此为fork()的子进程pid,因为进程中没有可以获取自己子进程pid的系统调用。此时就要把返回的pid保存起来,以后用来控制子进程。例如程序退出时调用kill(pid,9)杀死自己的子进程。
fork之后是父进程先执行还是子进程先执行,这是取决于cpu调用算法的,就是说他们谁先执行都有可能。

猜你喜欢

转载自zhangpuego.iteye.com/blog/1498206
今日推荐