深入理解fork()

 

                                            

最近经常在论坛上见到有初学者问关于fork()的很多疑惑。在这里把我关于fork()的体会和理解写出来供大家分享。对于fork()疑惑,无非是对于为什么fork()函数会执行一次,但是返回两次,在父进程中,返回子进程ID,在子进程中返回0.

 

 

这里就fork()的工作原理及过程进行分析。为了了解fork(),首先大家要有一个分岔的概念,也就是我上图中,fork()之后,会从fork()之后分岔出一个子进程B。fork()创建出一个子进程B,同时将父进程A的资源复制给进程B。子进程实质就是对父进程的复制。子进程出了和父进程共享字符text  段意外,其余的都是有自己独立的stack,heap。那么为什么fork()会返回2次呢?我们可以这么理解:在子进程中也有一个fork()在执行,那么他就会返回一个值。对于一个子进程来说,他可以有多个父进程,那么返回不同的数没有任何意思,所以返回0是最合适的,在父进程中,一个父进程可以有多个子进程,那么为了区分进程以及得到子进程号,所以在父进程中需要子进程返回一个子进程号。父进程永远没有办法主动获取子进程号的功能,也没有这种函数,处在在创建进程能返回子进程号之外。

 

     对于复制父进程来创建子进程,这种复制遵循各COW(copy-on-write)即为写时复制。内核并不是完全的复制所有的父进程资源给子进程。创建子进程之后,父进程会将父进程的资源标志为只读,当子进程需要改变资源的时候,就会发生复制,即复制该资源给子进程,让子进程单独自己去处理。

 

 



版权申明:
转载文章请注明原文出处http://blog.csdn.net/feiyinzilgd/archive/2010/07/20/5750853.aspx

并请联系谭海燕本人或者前往谭海燕个人主页留言

时间: 2024-10-05 19:54:42

深入理解fork()的相关文章

聊聊并发(八)——Fork/Join框架介绍

本文首发于InfoQ 1. 什么是Fork/Join框架 Fork/Join框架是Java7提供了的一个用于并行执行任务的框架, 是一个把大任务分割成若干个小任务,最终汇总每个小任务结果后得到大任务结果的框架. 我们再通过Fork和Join这两个单词来理解下Fork/Join框架,Fork就是把一个大任务切分为若干子任务并行的执行,Join就是合并这些子任务的执行结果,最后得到这个大任务的结果.比如计算1+2+..+10000,可以分割成10个子任务,每个子任务分别对1000个数进行求和,最终汇

Java Fork/Join框架_java

Fork/Join框架是ExecutorService接口的一个实现,通过它我们可以实现多进程.Fork/Join可以用来将一个大任务递归的拆分为多个小任务,目标是充分利用所有的资源尽可能增强应用的性能. 和任何ExecutorService接口的实现一样,Fork/Join也会使用线程池来分布式的管理工作线程.Fork/Join框架的独特之处在于它使用了work-stealing(工作窃取)算法.通过这个算法,工作线程在无事可做时可以窃取其它正在繁忙的线程的任务来执行. Fork/Join框架

《UNIX网络编程 卷2:进程间通信(第2版)》——1.5 fork、exec和exit对IPC对象的影响

1.5 fork.exec和exit对IPC对象的影响 我们需要理解fork.exec和_exit函数对于所讨论的各种形式的IPC的影响(_exit是由exit调用的一个函数).图1-6对此作了总结. 表中多数特性将在以后的章节中讲述,不过我们需要强调几点.首先,考虑到无名同步变量(互斥锁.条件变量.读写锁.基于内存的信号量),从一个具有多个线程的进程中调用fork将变得混乱不堪.[Butenhof 1997]的6.1节提供了其中的细节.我们在表中只是简单地注明:如果这些变量驻留在共享内存区中,

linux中fork创建进程讲解(转)

大家知道Linux中创建子进程的一个很好的方法是函数调用fork,但是很多初学者对fork的理解上可能有点困难.我们举个例子来看看fork的用法吧.         大家用fork的时候记住fork是"分叉"的意思就很好理解了.         记得初学fork() 函数及遇到这个函数时,总是不能理解fork为什么会这样写,就会分成父子两个进程.    先看一下fork() 的经典模式 //------------------------------------------------

如何搭建Web服务器(三)

在本系列的第二部分中,你创造了一个可以处理基本 HTTP GET 请求的.朴素的 WSGI 服务器.当时我问了一个问题:"你该如何让你的服务器在同一时间处理多个请求呢?"在这篇文章中,你会找到答案.系好安全带,我们要认真起来,全速前进了!你将会体验到一段非常快速的旅程.准备好你的 Linux.Mac OS X(或者其他 *nix 系统),还有你的 Python.本文中所有源代码均可在 GitHub 上找到. 服务器的基本结构及如何处理请求 首先,我们来回顾一下 Web 服务器的基本结构

搭个 Web 服务器(三)

"只有在创造中才能够学到更多." --皮亚杰 在本系列的第二部分中,你创造了一个可以处理基本 HTTP GET 请求的.朴素的 WSGI 服务器.当时我问了一个问题:"你该如何让你的服务器在同一时间处理多个请求呢?"在这篇文章中,你会找到答案.系好安全带,我们要认真起来,全速前进了!你将会体验到一段非常快速的旅程.准备好你的 Linux.Mac OS X(或者其他 *nix 系统),还有你的 Python.本文中所有源代码均可在 GitHub 上找到. 服务器的基本

Node.js中child_process实现多进程_node.js

复制代码 代码如下: var http = require('http'); function fib (n) {     if (n < 2) {         return 1;     } else {         return fib(n - 2) + fib(n - 1);     } } var server = http.createServer(function (req, res) {     var num = parseInt(req.url.substring(1)

Fork/Join框架简介

1. 什么是Fork/Join框架 Fork/Join框架是Java7提供了的一个用于并行执行任务的框架, 是一个把大任务分割成若干个小任务 ,最终汇总每个小任务结果后得到大任务结果的框架. 我们再通过Fork和Join这两个单词来理解下Fork/Join框架,Fork就是把一个大任务切分为若干子任务 并行的执行,Join就是合并这些子任务的执行结果,最后得到这个大任务的结果.比如计算1+2+..+ 10000,可以分割成10个子任务,每个子任务分别对1000个数进行求和,最终汇总这10个子任务

深入理解GIL:如何写出高性能及线程安全的Python代码

6岁时,我有一个音乐盒.我上紧发条,音乐盒顶上的芭蕾舞女演员就会旋转起来,同时,内部装置发出"一闪一闪亮晶晶,满天都是小星星"的叮铃声.那玩意儿肯定俗气透了,但我喜欢那个音乐盒,我想知道它的工作原理是什么.后来我拆开了,才看到它里面一个简单的装置,机身内部镶嵌着一个拇指大小的金属圆筒,当它转动时会拨弄钢制的梳齿,从而发出这些音符. 在一个程序员具备的所有特性中,想探究事物运转规律的这种好奇心必不可少.当我打开音乐盒,观察内部装置,可以看出即使我没有成长为一个卓越的程序员,至少也是有好奇