项目 | 内容 |
---|---|
这个作业属于哪个课程 | Linux系统与应用 |
这个作业的要求在哪里 | 实验六作业要求 |
学号-姓名 | 18043205-杨玉丹 |
作业学习目标 | 1.掌握Linux系统环境C语言编程概念;2.学习Linux系统进程概念 |
1.请举例说明静态链接库的创建与使用。
ar:建立,修改档案或从档案中抽取成员
ar -r :替换归档文件中已有的文件或加入新文件
ar -t :显示归档文件内容
//文件名:add.c,加法
//文件名:sub.c,减法
//文件名:main.c
2.请举例说明共享库的创建与使用。
//文件名:add.c
//文件名:sub.c
//文件名:main.c
开始的目录结构:
观察下面的目录结构,与开始的目录结构对比:
(1)创建共享库
使用自己的共享库:
方式一:
方式二:
3.编程实现一个简单文件复制命令。
mycp.c文件复制前:
复制后(test文件):
4.使用fork创建一个子进程,进程创建成功后父子进程分别输出不同的内容。
fork:创建一个子进程
全缓冲:
全缓冲指的是系统在填满标准IO缓冲区之后才进行实际的IO操作;
注意,对于驻留在磁盘上的文件来说通常是由标准IO库实施全缓冲。
行缓冲:
在这种情况下,标准IO在输入和输出中遇到换行符时执行IO操作;
注意,当流涉及终端的时候,通常使用的是行缓冲。
(1)删除fork1.c文件中 fflush(NULL);
./fork2 > /tmp/out 输出结果删除后子程序工作前多个 Begin!
(2)继续删除fork1.c文件中 “ printf("[%d]:Begin! \n",getpid()); ”
这一句中的“\n”结果和前面相比,Begin!之后都没有换行。
5.使用fork创建多个子进程。
这里请大家分析假如有下列代码段:
int i;
pid_t pid;
for (i = 0; i < 3; i++)
pid = fork();
上面代码段会产生多少子进程?
会产生: 2^3-1=7个子进程。
用sleep函数来控制进程输出顺序:
6.在fork之前以写的方式创建了一个文件 test.txt。然后fork出的子进程立即向文件中写入“world”,然后睡眠5秒。而父进程在 fork 后睡眠3秒后向 test.txt 写入 "hello",并关闭描述符。子进程恢复后,又向 test.txt 文件中写入 "lalala"后关闭描述符,结束。
7.分别在主函数中使用execvp启动ls命令以及使用fork函数产生子进程调用execvp启动ls。
(1)使用execvp启动ls命令:
(2)使用fork函数产生子进程调用execvp启动ls命令:
8.创建5个僵尸进程,并在终端通过ps axf命令查看僵尸进程信息。
在终端中新建一个窗口,输入:
ps axf //显示进程见关联的树状结构图
9.通过wait来清理僵尸进程。
wait(等待子进程中断或结束)
(1)表头文件:
#include<sys/types.h>
#include<sys/wait.h>
(2)定义函数: pid_t wait (int * status);
(3)函数说明:
wait()会暂时停止目前进程的执行,直到有信号来到或子进程结束。如果在调用wait()时子进程已经结束,则wait()会立即返回子进程结束状态值。子进程的结束状态值会由参数status 返回,而子进程的进程识别码也会一快返回。如果不在意结束状态值,则参status 可以设成NULL。
(4)返回值:
如果执行成功则返回子进程识别码(PID),如果有错误发生则返回-1,失败原因存于errno 中。
10.父进程通过waitpid函数等待特定子进程结束,若该子进程不结束,父进程一直阻塞。
waitpid
(1)函数功能:用来等待某个特定进程的结束
(2)函数原型:
pid_t waitpid(pid_t pid, int *status, int options);
(3)参数:
status如果不为空,会把状态信息写到它指向的位置
options允许改变waitpid的行为,最有用的一个选项是WNOHANG,它的作用是防止waitpid把调用者的执行挂起.
(4)返回值:成功返回等待子进程的pid,失败返回-1