linux下一个进程在内存里有三部分的数据,“代码段”、“堆栈段”、“数据段”。
“代码段”,存放程序代码的数据,如果机器中有数个进程运行相同的一个程序,那么它们就可以使用相同的代码段。
“堆栈段”,存放的就是子程序的返回地址、子程序的参数以及程序的局部变量。
“数据段”,存放程序的全局变量,常数以及动态数据分配的数据空间。
函数fork( )用来创建一个新的进程,该进程几乎是当前进程的一个完全拷贝。
函数族exec( )用来启动另外的进程以取代当前运行的进程。
fork( )
• 一个进程在运行中,如果使用了fork,就产生了另一个进程,于是进程就“分叉”了,所以这个名字很形象。
• 调用fork( )函数时,它会启动一个新的进程,这个进程几乎是当前进程的一个拷贝。子进程和父进程使用相同的代码段,子进程复制父进程的“堆栈段”、“数据段”。子进程一旦开始运行,虽然它继承了父进程的一切数据,但实际上数据却已经分开,相互之间不再有影响了。它们再要交互信息,只有通过进程间通信来实现。
一般CPU都是以“页”为单位来分配内存空间的,每一个页都是实际物理内存的一个映像,比如intel的cpu,其一页通常情况下是4086字节大小,无论是数据段还是堆栈段都是由许多“页”构成的。
fork()函数复制这两个段,只是“逻辑”上的,并非“物理”上的,也就是说实际执行fork()时,物理空间上两个进程的数据段和堆栈段都还是共享的,当有一个进程写了某个数据时,这时两个进程之间的数据才有了区别,系统就将有区别的“页”从物理上也分开,系统在空间上的开销就达到最小。
“代码段”,存放程序代码的数据,如果机器中有数个进程运行相同的一个程序,那么它们就可以使用相同的代码段。
“堆栈段”,存放的就是子程序的返回地址、子程序的参数以及程序的局部变量。
“数据段”,存放程序的全局变量,常数以及动态数据分配的数据空间。
函数fork( )用来创建一个新的进程,该进程几乎是当前进程的一个完全拷贝。
函数族exec( )用来启动另外的进程以取代当前运行的进程。
fork( )
• 一个进程在运行中,如果使用了fork,就产生了另一个进程,于是进程就“分叉”了,所以这个名字很形象。
• 调用fork( )函数时,它会启动一个新的进程,这个进程几乎是当前进程的一个拷贝。子进程和父进程使用相同的代码段,子进程复制父进程的“堆栈段”、“数据段”。子进程一旦开始运行,虽然它继承了父进程的一切数据,但实际上数据却已经分开,相互之间不再有影响了。它们再要交互信息,只有通过进程间通信来实现。
一般CPU都是以“页”为单位来分配内存空间的,每一个页都是实际物理内存的一个映像,比如intel的cpu,其一页通常情况下是4086字节大小,无论是数据段还是堆栈段都是由许多“页”构成的。
fork()函数复制这两个段,只是“逻辑”上的,并非“物理”上的,也就是说实际执行fork()时,物理空间上两个进程的数据段和堆栈段都还是共享的,当有一个进程写了某个数据时,这时两个进程之间的数据才有了区别,系统就将有区别的“页”从物理上也分开,系统在空间上的开销就达到最小。