实验六 进程基础
1. 使用 fork 创建一个子进程,进程创建成功后父子进程分别输出不同的内容
![](https://img2020.cnblogs.com/blog/2391040/202106/2391040-20210610233117831-773626614.png)
下面根据行缓冲和全缓冲来分析大家在写程序时经常出现的一些问题,大家自行搜索行缓冲和全缓冲的
概念
接下来再修改代码
![](https://img2020.cnblogs.com/blog/2391040/202106/2391040-20210610233611030-1288050779.png)
![](https://img2020.cnblogs.com/blog/2391040/202106/2391040-20210610233618409-1539648332.png)
2. 使用fork创建多个子进程
这里请大家分析假如有下列代码段:
int i;
pid_t pid;
for (i = 0; i < 3; i++)
pid = fork();
上面代码段会产生多少子进程?
会产生: 2^3-1=7个子进程。但实际上只有3个是父进程产生的,其余都为子进程 fork()出来的。父进程fork了3个子进程,第1个子进程执行完之后又fork了2个进程,第2个子进程fork了1个进程。
![](https://img2020.cnblogs.com/blog/2391040/202106/2391040-20210610235910397-335203456.png)
这个程序输出每个进程之间的顺序是随机的,这里我们简单的用 sleep 函数来控制进程输出顺序,第一
个子进程最先输出,后面依次输出,最后父进程输出。
![](https://img2020.cnblogs.com/blog/2391040/202106/2391040-20210611000404903-2028239916.png)
![](https://img2020.cnblogs.com/blog/2391040/202106/2391040-20210611000318147-870491951.png)
3. 在 fork 之前以写的方式创建了一个文件 test.txt。然后 fork 出的子进程立即向文件中写入
“world”,然后睡眠5秒。而父进程在 fork 后睡眠3秒后向 test.txt 写入 "hello",并关闭描述符。子进程恢复后,又向 test.txt 文件中写入 "lalala"后关闭描述符,结束。
![](https://img2020.cnblogs.com/blog/2391040/202106/2391040-20210611000732892-617555091.png)
![](https://img2020.cnblogs.com/blog/2391040/202106/2391040-20210611000605748-2050604263.png)
4. 使用 execvp 启动 ls 命令
![](https://img2020.cnblogs.com/blog/2391040/202106/2391040-20210611001123290-1218820752.png)
![](https://img2020.cnblogs.com/blog/2391040/202106/2391040-20210611001021610-1123883878.png)
接下来使用 fork 函数产生子进程调用 execvp 启动 ls
![](https://img2020.cnblogs.com/blog/2391040/202106/2391040-20210611001505989-420977761.png)
![](https://img2020.cnblogs.com/blog/2391040/202106/2391040-20210611001404608-1329186736.png)
5. 创建5个僵尸进程,并在终端通过 ps 命令查看僵尸进程信息
另开一个终端用 ps 命令来查看僵尸进程信息
![](https://img2020.cnblogs.com/blog/2391040/202106/2391040-20210610233744230-179216598.png)
通过 wait 来清理僵尸进程
![](https://img2020.cnblogs.com/blog/2391040/202106/2391040-20210610235211840-1612406012.png)