Linux_父子进程与fork
进程标识每个进程都有一个非负整数表示的唯一进程ID,如交换进程(即调度进程)ID为0,init进程ID为1,页守护进程ID为2;函数fork原型如下:fork函数被调用一次,但返回两次,两次返回的区别就是子进程返回的是0,父进程返回的新子进程的ID;子进程是父进程的副本,获得了父进程数据空间、堆和栈的副本;父子进程并不共享这些存储空间,共享正文段(即代码段);因此子进程
·
进程标识
每个进程都有一个非负整数表示的唯一进程ID,如交换进程(即调度进程)ID为0,init进程ID为1,页守护进程ID为2;
函数fork
原型如下:
fork函数被调用一次,但返回两次,两次返回的区别就是子进程返回的是0,父进程返回的新子进程的ID;
子进程是父进程的副本,获得了父进程数据空间、堆和栈的副本;父子进程并不共享这些存储空间,共享正文段(即代码段);因此子进程对变量的所做的改变并不会影响父进程。
目前采用了写时复制(Copy-On-Write,COW)技术(即fork之后,子进程不会立马执行exec)负责管理父子进程的存储空间关系。数据段、堆栈这些区域是父进程和子进程共享的,只有进程空间的各段的内容要发生变化时,才会将父进程的内容复制一份给子进程。
示例如下:
#include<unistd.h>
#include<stdio.h>
int globvar=6;
int main()
{
int var=88;
pid_t pid;
printf("before fork\n");
if((pid=fork())<0)
printf("fork error");
else if(pid==0) //child
{
globvar=23;
var =33;
}
else sleep(2); //parent
var=1;
printf("pid=%ld,glob=%d,var=%d\n",(long)getpid(),globvar,var);
return 0;
}
运行结果如下:
参考书籍:《Unix环境高级编程(第三版)》P182
更多推荐
已为社区贡献3条内容
所有评论(0)