在学习unix编程时 发现 书上写了 fork 函数执行一个返回两次 ,这个让人莫不着头脑。函数调用一次返回两次不可思议。
fork 函数 会创建一个子进程,那么这个子进程会复制父进程的上下文,系统将给予它相关的运行内存空间,cpu。
在当我们执行fork函数时,内核就开始复制上下文,那么fork创建的子进程,也是一个可执行的程序,那么他会从fork函数开始处开始运行
if((pid=fork()) <0){
printf("fork error!\n");
err_sys("fork_error");
}else if(pid==0){
printf("child process\n");
glob++;
var++;
}else{
printf("sleep 2 second pid=%d\n",getpid());
//sleep(2);
}
printf("pid=%d,glob=%d,var=%d\n",getpid(),glob,var);
首先由于cpu时间的分配关系, 父进程将继续运行,父进程要管理子进程必须知道子进程ID,那么子进程也是一个独立在操作系统的进程,同时它肯定是一个不为0的ID号的进程。
上面的代码事实上会在父进程和子进程中都保存这一份。这样进程继续运行,由于父进程内不会返回ID 为0,故执行else块代码,直到父进程执行完毕。
父进程执行完毕后,cpu分配时间到子进程,继续运行,调用fork 函数,内核的IOS 会进行标记。使得 fork 函数 返回0 ,进入判断 pid=0执行我们的else if 条件的代码。
为了区分出来可以在父进程运行时sleep,让其让出cpu时间,让子进程先走,当然这一也不一定,这个时间有操作系统来决定的,这里的2秒够长了。看看最后打印的值 。
子进程的上下文拷贝的改变完全不应想父进程