fork函数
- pid_t fork(void):创建一个子进程。
- 返回值:子进程的PID返回给父进程
: 0 返回给子进程本身
- 特性
(1)所创建的进程复制父进程的代码段/数据段/BSS段/堆/栈等所有用户空间信息。
(2)在内核中操作系统重新为其申请了一个PCB,并使用父进程的PCB进行初始化。
(3)子进程执行的位置是fork()函数执行后的代码处。
(4)这两个进程执行没有固定的先后顺序,哪个进程先执行要看系统的进程调度策略。
实例:
结果:父进程 和 子进程 谁先执行完是不确定的
循环创建子进程
1 #include <stdio.h>
2 #include <stdlib.h>
3 #include <unistd.h>
4
5 int main(void)
6 {
7 pid_t pid;
8 int i=0;
9 printf("------------------------\n");
10
11 for(i=0;i<5;i++)
12 {
13 pid=fork();
14
15 if(pid<0)
16 {
17 perror("fork error");
18 }
19 if(pid == 0)
20 {
21 break; //每个子进程创建之后直接跳出循环,防止子进程创建子进程
22 }
23
24 }
25
26 sleep(i); // 加上睡眠,控制时间,子进程 1 不睡,2睡1ms,3睡2ms.....父进程睡5ms ,
27 if(i<5) //son break out
28 {
29 printf("i am %dth child ,my id is %d\n",i , getpid());
30 }
31 else //父进程for循环执行完之后 跳出 ,i==5
32 {
33 printf("i am father , my id is %d\n",getpid());
34 }
35 return 0;
36 }
结果:
父子进程共享
- 相同点:全局变量、.data、.text、栈、堆、环境变量、信号处理方式等
- 不同点:进程ID、fork返回值、各自父进程、运行时间、定时器、未决信号集
- 父子进程遵循读时共享、写时复制的原则
- 父子进程共享:(1)文件描述符 (2)mmap建立的映射区