fork函数
1.描述
创建一个子进程。
fork()通过复制当前进程来创建一个新的进程,新进程被称为子进程,当前进程被称为父进程。
子进程和父进程在各自独立的内存空间中运行,在fork时,两个内存空间具有相同的内容。一个进程执行的操作不会影响另一个进程。
子进程和父进程完全相同,除了以下几点:
- 子进程具有其唯一的进程ID(PID),并且此PID与任何现有的进程组的ID都不匹配。(setpgid(2))
- 子进程的父进程ID与父进程的进程ID相同。
- 子进程不会继承父进程的内存锁。(mlock(2),mlockall(2))
- 子进程中的进程资源利用率和CPU时间计数器会被重置为0。(getrusage(2),time(2))
- 子进程的挂起信号集最初是空的。(sigpending(2))
- 子进程不会从父进程继承信号量的操作。(semop(2))
- 子进程不会从父进程继承记录锁。(fcntl(2))
- 子进程不会从父进程继承计时器。(settitimer(2),alarm(2),timer_create(2))
- 子进程不会从父进程继承未完成的异步I/O操作,也不会从父进程继承任何异步I/O的上下文。(aio_read(3),aio_write(3),io_setup(2))
详细可以查看man fork
2.头文件
#include <sys/types.h>
#include <unistd.h>
3.声明
pid_t fork(void);
4.参数
无
5.返回值
pid_t
成功后,将在父进程中返回子进程的PID,并在子进程中返回0。如果失败,则在父进程中返回-1,不创建任何子进程,并适当设置errno。
6.实例
#include<unistd.h>
#include<stdio.h>
#include<stdlib.h>
int main(int argc, char* argv[]) {
pid_t pid = fork();
if (pid < 0) {
fprintf(stderr, "错误!");
}
else if (pid == 0) {
printf("子进程空间");
exit(0);
}
else {
printf("父进程空间,子进程pid为%d", pid);
}
// 可以使用wait或waitpid函数等待子进程的结束并获取结束状态
exit(0);
}