一、fork()
我们可以利用fork,这个系统调用来复制当前进程,创建新进程,即在进程表中创建新的表项。
调用fork()的进程称为“父进程”,创建出来的新进程叫做“子进程”。
子进程的许多属性和当前的进程是一模一样的,例如新进程和原有进程的可执行程序是同一个程序,上下文和数据,绝大部分就是原进程(父进程)的拷贝,但它们是两个相互独立的进程!
而且新进程有自己的数据空间、环境和文件描述符。
二、fork的声明:
#include <sys/types.h>
#include <unistd.h>
pid_t fork(void);
调用fork的结果图见下:
三、fork调用一次,返回两次。在父进程中的fork调用返回的是新的子进程的PID,子进程中的fork调用返回的是0,父子进程可以通过这一点来判断究竟谁是父进程,谁又是子进程。
并且,fork调用产生新子进程之后,新子进程就和父进程一样,将继续执行fork调用后面的程序。
见下面的代码:
int main()
{
int n = 0;
char *s = NULL;
pid_t pid = fork();//fork调用
assert(pid != -