信息工程学院
实 验 报 告
课程名称:计算机操作系统教程 实验名称: 进程管理
实验类型:验证性√综合性□设计性□ 实验室名称:计算机应用实验室 班级:学号 姓名: 组别: 同组人:成绩: 实验日期:
1
内蒙古工业大学信息工程学院
报告类型:实验报告□ 预习报告√ 实验报告成绩: 指导教师审核(签名): 一、 实验目的
1.学会在Linux中利用系统调用fork()创建进程。 2.加深对进程概念的理解,明确进程和程序的区别。 3.进一步认识在系统内进程并发执行的实质。
4.分析进程竞争资源的现象,学习解决进程互斥与同步的方法。
二、实验类型
验证性实验。
三、实验预备知识
1.阅读Linux的sched.h源码文件,加深对进程管理概念的理解。 2.阅读Linux的fork.c源码文件,分析进程的创建过程。
四、实验内容
1.进程的创建 【任务】
编写一段程序,使用系统调用fork()创建两个子进程,当此程序运行时,在系统中有一个父进程和两个子进程活动。让每一个进程在屏幕上显示一个字符;父进程显示字符“a”,子进程分别显示字符“b”和“c”。试观察记录屏幕上的显示结果,并分析原因。
【程序】 #include
int p1,p2;
while((p1=fork())= =-1); /*创建子进程p1,失败时循环*/ if(p1= =0) /*子进程p1创建成功*/ putchar(?b?);
else /*父进程返回*/ {
while((p2=fork())= =-1); /*创建另一个子进程p2,失败时循环*/ if(p2= =0) /*子进程p2创建成功*/
2 第 页
内蒙古工业大学信息工程学院
putchar(?c?); else
putchar(?a?); /*父进程执行*/ } }
【执行结果】
同学自己得到实验结果。 【分析原因】
同学自己分析多次执行产生不同实验结果的原因。
2.进程的控制 【任务】
修改已编写的程序,将每个进程的输出由单个字符改为一句话,再观察程序执行时屏幕上出现的现象,并分析其原因。如果在程序中使用系统调用lockf()来给每个进程加锁,可以实现进程之间的互斥,观察并分析出现的现象。
【程序1】 #include
int p1,p2,i;
while((p1=fork())= =-1); if(p1= =0)
for(i=0;i<50;i++) printf(“child %d\\n”,i); else
{
while((p2=fork())= =-1) if(p2= =0)
for(i=0;i<50;i++) printf(“son %d\\n”,i); else
for(i=0;i<50;i++)
3 第 页
内蒙古工业大学信息工程学院
printf(“daughter %d\\n”,i); } }
【执行结果】
同学自己得到实验结果。 【分析原因】
同学自己分析多次执行产生不同实验结果的原因。 【程序2】 #include
int p1,p2,i;
while((p1=fork())= =-1); if(p1= =0) {
lockf(1,1,0); /*加锁*/ for(i=0;i<50;i++) printf(“child %d\\n”,i); lockf(1,0,0); /*解锁*/ } else
{
while((p2=fork())= =-1) if(p2= =0) {
lockf(1,1,0); for(i=0;i<50;i++) printf(“son %d\\n”,i); lockf(1,0,0); } else
第 4 页
内蒙古工业大学信息工程学院
{
lockf(1,1,0); for(i=0;i<50;i++)
printf(“daughter %d\\n”,i); lockf(1,0,0); } } }
【执行结果】
同学自己得到实验结果。 【分析原因】
同学自己分析多次执行产生不同实验结果的原因。第 5 页