赞
踩
- #include<unistd.h>
-
- pid_t fork(void);
- //返回值:子进程返回 0 ,父进程返回子进程的 id ,发生错误返回 -1。
进程调用fork后,当控制转移到内核中的fork代码后,内核做:
1.分配新的内核块和内核数据结构给子进程。
2.将父进程部分数据结构内容拷贝给子进程。
3.添加子进程到进程列表当中。
4.fork返回,开始调度器调度。
通常,父子代码共享,父子再不写入时,数据也是共享的,当任意一方试图写入,便以写时拷贝的方式各自一份副 本。具体见下图:
进程创建后,页表将代码和数据都设置为只读。操作系统检测到有写入操作时,会发生缺页中断(进程对不可写入的地址进程操作,系统检测到异常后进入中断)。操作系统重新开辟空间,将数据拷贝一份,子进程改变映射关系。(代码共享,数据拷贝)能够保持进程的独立性。
fork通常如何使用?
一个父进程希望复制自己,让父子进程同时执行不同的代码段。例如,父进程等待客户端请求,生成子进程来处理请求。
一个进程要执行一个不同的程序。例如子程序从fork返回后,调用exec函数。
fork调用失败的原因?
系统中有太多的进程。
实际用户的进程数超过了限制。
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。