fork()
是一个在Unix、Linux和类Unix操作系统中常见的系统调用,用于创建一个新的进程(子进程)。
它的工作方式是,调用 fork()
时,会复制当前进程(称为父进程)的所有资源,包括内存、变量、文件描述符等,创建一个与父进程几乎完全相同的子进程。然后,这两个进程将在各自的上下文中并行执行。
在 fork()
调用后,操作系统会在父进程和子进程之间进行区分。父进程会接收到子进程的进程ID(PID),而子进程会返回0。这样父子进程可以根据返回值来区分自己的角色。
fork()
的调用方式如下:
#include <unistd.h>
pid_t fork(void);
pid_t
是一个整数类型,用来表示进程ID。- 在父进程中,
fork()
返回新创建的子进程的PID。 - 在子进程中,
fork()
返回0,表示当前进程是子进程。 - 如果发生错误,
fork()
返回-1,表示创建子进程失败。
下面是一个示例,演示了 fork()
的基本用法:
#include <stdio.h>
#include <unistd.h>
int main() {
pid_t pid = fork();
if (pid == 0) {
printf("这是子进程\n");
printf("子进程的ID是: %d\n", getpid());
} else if (pid > 0) {
printf("这是父进程\n");
printf("父进程的ID是: %d\n", getpid());
printf("子进程的ID是: %d\n", pid);
} else {
perror("fork");
}
return 0;
}
这段C代码创建了一个新进程,父子进程分别打印了自己的进程ID。在子进程中,fork()
返回0,父进程中返回子进程的PID。
需要注意的是,fork()
是一个强大但也复杂的系统调用,需要小心地使用它,以避免产生意外的结果或资源泄露。