一个进程,包括代码、数据和分配给进程的资源。fork()函数通过系统调用创建一个与原来进程几乎完全相同的进程,也就是两个进程可以做完全相同的事,但如果初始参数或者传入的变量不同,两个进程也可以做不同的事。
一个进程调用fork()函数后,系统先给新的进程分配资源,例如存储数据和代码的空间。然后把原来的进程的所有值都复制到新的新进程中,只有少数值与原来的进程的值不同。相当于克隆了一个自己
示例代码:
#include <stdio.h>
#include <sys/types.h>
#include <unistd.h>
int main(void)
{
pid_t p1 = -1;
p1 = fork(); // 返回2次
printf(" p1 = %d.\n", p1);
if (p1 == 0)
{
// 子进程
// 先sleep一下让父进程先运行,先死
sleep(10);
printf("child process , pid = %d.\n", getpid());
printf("hello world.\n");
printf("child process, father process ID = %d.\n", getppid());
}
if (p1 > 0)
{
//父进程
printf("father process, pid = %d.\n", getpid());
printf("father process, p1 = %d.\n", p1);
}
if (p1 < 0)
{
//fork出错了
}
return 0;
}
日志:
@R720:~/LinuxStudy/process$ ./test
p1 = 36126.
father process, pid = 36125.
father process, p1 = 36126.
p1 = 0.
@R720:~/LinuxStudy/process$ child process , pid = 36126.
hello world.
child process, father process ID = 1.
总结:
1、进程的分裂生长模式。如果操作系统需要一个新进程来运行一个程序,那么操作系统会用一个现有的进程来复制生成一个新进程。老进程叫父进程,复制生成的新进程叫子进程
2、fork函数调用一次会返回2次,返回值等于0的就是子进程,而返回值大于0的就是父进程。
典型的使用fork的方法:使用fork后然后用if判断返回值,并且返回值大于0时就是父进程,等于0时就是子进程
3、fork的返回值在子进程中等于0,在父进程中等于本次fork创建的子进程的进程ID。