![操作系统实验指导书V2013[1]_第1页](http://file3.renrendoc.com/fileroot_temp3/2022-3/14/332f24e3-cd5d-49a8-aedc-2c5c396cb6dd/332f24e3-cd5d-49a8-aedc-2c5c396cb6dd1.gif)
![操作系统实验指导书V2013[1]_第2页](http://file3.renrendoc.com/fileroot_temp3/2022-3/14/332f24e3-cd5d-49a8-aedc-2c5c396cb6dd/332f24e3-cd5d-49a8-aedc-2c5c396cb6dd2.gif)
![操作系统实验指导书V2013[1]_第3页](http://file3.renrendoc.com/fileroot_temp3/2022-3/14/332f24e3-cd5d-49a8-aedc-2c5c396cb6dd/332f24e3-cd5d-49a8-aedc-2c5c396cb6dd3.gif)
![操作系统实验指导书V2013[1]_第4页](http://file3.renrendoc.com/fileroot_temp3/2022-3/14/332f24e3-cd5d-49a8-aedc-2c5c396cb6dd/332f24e3-cd5d-49a8-aedc-2c5c396cb6dd4.gif)
![操作系统实验指导书V2013[1]_第5页](http://file3.renrendoc.com/fileroot_temp3/2022-3/14/332f24e3-cd5d-49a8-aedc-2c5c396cb6dd/332f24e3-cd5d-49a8-aedc-2c5c396cb6dd5.gif)
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、操作系统实验指导书 操作系统课程组 编内蒙古工业大学信息工程学院计算机系二一三年九月目 录操作系统实验教学大纲1实验一 进程管理1实验二 SPOOLing技术实现12I操作系统实验教学大纲一、基本信息课程编码020213008课程学时56课程类别学科基础课程实验总学时10开出学期5开出单位计算机系适用专业计算机科学与技术、软件工程二、实验安排序号实 验 项 目实验学时每组人数实验类型开出要求1实验一 进程管理41验证必做实验二 SPOOLing技术实现61设计必做三、实验目的、内容与要求实验一 进程管理(一)实验目的1加深对进程概念的理解,明确进程和程序的区别;2进一步认识并发执行的实质;3分
2、析进程争用资源的现象,学习解决进程互斥的方法;4了解Linux系统中进程通信的基本原理。(二)实验内容1进程的创建;2进程的控制;3进程的软中断通信;4进程的管道通信。(三)实验要求1掌握Linux系统中进程的创建、控制和通信的实现;2根据实验内容,在Linux平台上用C语言编程实现,上机调试运行得出实验结果;3写出预习报告和实验报告。实验二 SPOOLing技术实现(一)实验目的1加深对SPOOLing系统的理解;2进一步认识SPOOLing技术的实质;3分析、设计SPOOLing系统的实现方法;4了解Linux系统中SPOOLing的基本原理。(二)实验内容设计并运行一个简单的SPOOLi
3、ng系统来模拟实际的SPOOLing输入/输出过程,以掌握这种以空间换时间的技术。要求将SPOOLing输入/输出处理程序编成一个独立的进程模块并与其他请求输入/输出的进程并发运行。SPOOLing进程负责把从输入设备输入的信息送到外存输入井中,或把外存输出井中的信息送到打印机等输出设备上输出。其余进程只要求编写输入/输出部分的程序。要求定义实施算法的相关数据结构,实现设备分配和SPOOLing算法。(三)实验要求1掌握SPOOLing技术的实现;2根据实验内容,在Linux平台上用C语言编程实现,上机调试运行得出实验结果;3写出预习报告和实验报告。四、考核方式实验成绩占课程总成绩的比重为10
4、%。考核方式根据实验课考勤、课前预习情况、课上实验能力、原型系统效果验收与实验报告的完成情况综合评分。每个实验考核:实验预习占30%,实验能力和效果占30%,实验报告占40%。五、建议教材与教学参考书1课程教材1 张尧学. 计算机操作系统教程. 第三版. 北京:清华大学出版社. 20062 赵俊生操作系统实验指导书自编20082教学参考书1 汤小丹计算机操作系统第三版西安: 西安电子科技大学出版社2008 2 徐虹. 操作系统实验指导. 北京: 清华大学出版社20043 屠祁. 操作系统基础第三版北京: 清华大学出版社20004 冯耀霖. 操作系统. 西安: 西安电子科技大学出版社20015
5、左万历计算机操作系统教程第二版北京:高等教育出版社2004六、编制说明编制者:系统软件课程组 组长:寿永熙执笔人:赵俊生 编制时间:2009年3月15实验一 进程管理一、 实验目的1学会在Linux中利用系统调用fork()创建进程。2加深对进程概念的理解,明确进程和程序的区别。3进一步认识在系统内进程并发执行的实质。4分析进程竞争资源的现象,学习解决进程互斥的方法。5掌握Linux中进程通信的基本原理。二、 实验类型验证性实验。三、 实验预备知识 1阅读Linux的sched.h源码文件,加深对进程管理概念的理解。 2阅读Linux的fork.c源码文件,分析进程的创建过程。四、 实验内容
6、1进程的创建 【任务】 编写一段程序,使用系统调用fork()创建两个子进程,当此程序运行时,在系统中有一个父进程和两个子进程活动。让每一个进程在屏幕上显示一个字符;父进程显示字符“a”,子进程分别显示字符“b”和“c”。试观察记录屏幕上的显示结果,并分析原因。【程序】include <stdio.h>main() int p1,p2; while(p1=fork()= =-1); /*创建子进程p1,失败时循环*/ if(p1= =0) /*子进程p1创建成功*/ putchar(b); else /*父进程返回*/ while(p2=fork()= =-1); /*创建另一个子
7、进程p2,失败时循环*/ if(p2= =0) /*子进程p2创建成功*/ putchar(c); else putchar(a); /*父进程执行*/ 【执行结果】 同学自己得到实验结果。 【分析原因】 同学自己分析多次执行产生不同实验结果的原因。2进程的控制【任务】修改已编写的程序,将每个进程的输出由单个字符改为一句话,再观察程序执行时屏幕上出现的现象,并分析其原因。如果在程序中使用系统调用lockf()来给每个进程加锁,可以实现进程之间的互斥,观察并分析出现的现象。【程序1】include <stdio.h>main() int p1,p2,i; while(p1=fork(
8、)= =-1); if(p1= =0) for(i=0;i<50;i+) printf(“child %dn”,i); else while(p2=fork()= =-1) if(p2= =0) for(i=0;i<50;i+) printf(“son %dn”,i); else for(i=0;i<50;i+) printf(“daughter %dn”,i); 【执行结果】 同学自己得到实验结果。 【分析原因】同学自己分析多次执行产生不同实验结果的原因。【程序2】include <stdio.h>include <unistd.h>main() i
9、nt p1,p2,i; while(p1=fork()= =-1); if(p1= =0) lockf(1,1,0); /*加锁*/ for(i=0;i<50;i+) printf(“child %dn”,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 %dn”,i); lockf(1,0,0); else lockf(1,1,0); for(i=0;i<50;i+) printf(“daughter %dn”,i
10、); lockf(1,0,0); 【执行结果】 同学自己得到实验结果。 【分析原因】 同学自己分析多次执行产生不同实验结果的原因。3软中断通信【任务1】编制一段程序,使用系统调用fork()创建两个子进程,再用系统调用signal()让父进程捕捉键盘上来的中断信号(即按任意字母键和Enter键),当捕捉到中断信号后,父进程用系统调用kill()向两个子进程发出信号,子进程捕捉到信号后,分别输出下列信息后终止: child process 1 is killed by parent! child process 2 is killed by parent!父进程等待两个子进程终止后,输出以下信息
11、后终止:parent process is killed!【程序】#include <sys/types.h>#include <unistd.h>#include <stdio.h>#include <signal.h>void waiting(),stop();int wait_mark;main() int p1,p2; while(p1=fork()= =-1); /*创建进程p1*/ if(p1>0) while(p2=fork()= =-1); /*创建进程p2*/ if(p2>0) Printf(“parent run!
12、n”); Printf(“p1=%dn”,p1); Printf(“p2=%dn”,p2); wait_mark=1;getchar(); kill(p1,16); /*向p1发软中断信号16*/kill(p2,17); /*向p2发软中断信号17*/sleep(5); /*父进程睡眠5秒*/wait(0); /*等待子进程结束,同步*/wait(0); /*等待另一子进程结束,同步*/lockf(stdout,1,0); /*标准输出加锁*/printf(“parent process is killed!n”);lockf(stdout,0,0); /*标准输出解锁*/exit(0); /
13、*父进程终止*/ else printf(“p2 run!n”); wait_mark=1;signal(17,stop); /*接收父进程发来的软中断信号17,并转stop*/waiting();lockf(stdout,1,0); /*标准输出加锁*/printf(“child process 2 is killed by parent!n”);lockf(stdout,0,0); /*标准输出解锁*/exit(0); /*子进程p2终止*/ else printf(“p1 run!n”); wait_mark=1;signal(16,stop); /*接收父进程发来的软中断信号16,并转
14、stop*/waiting();lockf(stdout,1,0); /*标准输出加锁*/printf(“child process 1 is killed by parent!n”);lockf(stdout,0,0); /*标准输出解锁*/exit(0); /*子进程p1终止*/ void waiting() printf(“waiting begin!n”); while(wait_mark!=0); printf(“waiting end!n”); void stop() wait_mark=0; printf(“signal stop!”); 【执行结果】 同学自己得到实验结果。 【
15、分析原因】 同学自己分析产生该实验结果的原因。 【任务2】 在上面任务1中,增加语句signal(SIGINT,SIG_IGN)和语句signal(SIGQUIT,SIG_IGN),观察执行结果,并分析原因。这里signal(SIGINT,SIG_IGN)和signal(SIGQUIT,SIG_IGN)分别为忽略“Ctrl+c”键信号以及忽略中断信号。 【程序】#include <sys/types.h>#include <unistd.h>#include <stdio.h>#include <signal.h> int pid1,pid2;
16、int endflag=0,pf1=0,pf2=0; void intdelete() kill(pid1,16); kill(pid2,17); endflag=1; void int1() printf(“child process 1 is killed by parent!”); exit(0); void int2() printf(“child process 2 is killed by parent!”); exit(0); main() int exitpid; signal(SIGINT,SIG_IGN); signal(SIGQUIT,SIG_IGN); while(pi
17、d1=fork()= =-1); if(pid1= =0) printf(“process 1 run!n”); signal(SIGUSR1,int1); signal(16, SIG_IGN); pause(); exit(0); else while(pid2=fork()= =-1); if(pid2= =0) printf(“process 2 run!n”); signal(SIGUSR2,int2); signal(17, SIG_IGN); pause(); exit(0); else printf(“parent run!n”); signal(SIGINT,intdelet
18、e); waitpid(-1,&exitpid,0); printf(“parent process is killed!n”); exit(0); 【执行结果】 同学自己得到实验结果。 【分析原因】 同学自己分析产生该实验结果的原因。4进程的管道通信【任务】 编制一段程序,实现进程的管道通信。使用系统调用pipe()建立一条管道线。两个子进程p1和p2分别向管道各写一句话: child 1 is sending a message! child 2 is sending a message! 而父进程则从管道中读出来自于两个子进程的信息,显示在屏幕上。 【程序】#include &l
19、t;unistd.h>#include <stdio.h>#include <signal.h> int pid1,pid2; main() int fd3; char outpipe100,inpipe100; pipe(fd); while(pid1=fork()= =-1); if(pid1= =0) printf(“p1 run!n”); lockf(fd1,1,0); sprintf(outpipe,”child 1 process is sending a message!”); write(fd1,outpipe,50); sleep(1); loc
20、kf(fd1,0,0); exit(0); else while(pid2=fork()= =-1); if(pid2= =0) printf(“p2 run!n”); lockf(fd1,1,0); sprintf(outpipe,”child 2 process is sending a message!”); write(fd1,outpipe,50); sleep(1); lockf(fd1,0,0); exit(0); else printf(“parent run!n”); wait(0); read(fd0,inpipe,50); printf(“%sn”,inpipe); wa
21、it(0); read(fd0,inpipe,50); printf(“%sn”,inpipe); exit(0); 【执行结果】 同学自己得到实验结果。 【分析原因】 同学自己分析产生该实验结果的原因。实验二 SPOOLing技术实现一、实验目的1加深对SPOOLing (Simultaneaus Periphernal Operating OnLine)系统组成与基本工作原理的理解。2使用客户/服务器模式进行程序设计。3使用Linux进程技术,模拟SPOOLing系统中输出进程的工作。4使用Linux进程通信技术,模拟SPOOLing系统工作进程与输出进程的数据输出。5使用Linux文件技
22、术,模拟SPOOLing系统输出井的工作过程。二、实验类型设计性实验。三、实验预备知识 1阅读Linux进程通信技术(消息和管道)的使用方法。 2阅读Linux文件操作技术,掌握文件的基本处理方法。四、实验内容 假脱机打印是SPOOLing系统的典型应用。本次实验的内容就是以客户/服务器模式模拟假脱机打印的工作过程。工作原理见图2-1。打印服务器输入缓存区打印队列输出井客户机1请求打印打印文件输出缓存区数据传输客户机n请求打印数据传输.图2-1 模拟假脱机打印工作原理整个系统的工作是先启动打印服务器,初始化客户/服务器间的通信、准备输入缓存区、打印队列和输出井。然后启动请求打印的客户机程序(如命令:printmn file.dat),将要打印的文件(如:file.dat)读入客户机系统,包装成客户机和服务器之间通信的基本信息单位,放入输出缓存区,然后启动进程间通信机制,向打印服务器发出请求。服务器通过进程间的通信机制,将客户机传送的数据放入输出缓存区,并向打印队列申请
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 花儿生肖测试题及答案
- 涪陵教师面试题及答案
- 普通遗传学 试题及答案
- 数学在生活中的应用试题及答案
- 施工工艺与安全管理关联试题及答案
- 供应链风险管理体系在资源优化配置领域的应用与案例分析报告
- 英语商业演示技巧与表达能力试题及答案
- 河南特岗招聘试题及答案
- 老年教育课程设置与教学模式创新:2025年发展趋势报告
- 家具设计中的用户参与设计考题及答案
- 机动车维修竣工出厂合格证样式
- 幼儿园中班歌唱:《母鸡孵蛋》 课件
- GB/T 36447-2018多媒体教学环境设计要求
- GB/T 14832-2008标准弹性体材料与液压液体的相容性试验
- 电机检测报告
- 内镜下逆行阑尾炎治疗术
- SJG 82-2020 政府投资学校建筑室内装修材料空气污染控制标准-高清现行
- 《脂蛋白(a)与心血管疾病风险关系及临床管理的专家科学建议》(2021)要点汇总
- 2004年武汉房地产市场情况分析报告(共23页)
- 肿瘤化学治疗
- RMG88.62C2控制器报警显示及可能的故障原因 - 副本
评论
0/150
提交评论