linux中fork函数是非常重要的函数,从已经存在的进程中创建一个新进程。新进程是子进程,原进程是父进程。

RETURN VALUE
On success, the PID of the child process is returned in the parent, and 0 is returned in the child. On failure, -1 is returned in the parent, no child process is created, and errno is set appropriately.
返回值:
成功时,父进程返回子进程的id,子进程返回0;
失败时,父进程返回-1,子进程没有被创建。
当一个进程调用fork之后,就有两个二进制代码相同的进程,而且都运行到相同的地方,但每个进程都将开启自己的旅程。

fork之前父进程独立执行,fork之后,父子进程分别执行。
fork之后,谁先执行完全由调度器决定!!!
通常,父子进程共享,父子不写入时,数据也是共享的,但是当一方试图写入时,就用 写时拷贝的方式各自拷贝一份副本。

1、当一个父进程希望复制自己,使父子进程同时执行不同的代码。
2、一个进程执行一个不同的程序
系统中有太多进程,或者,实际用户的进程数超过限制,fork会调用失败。