第五讲(进程管理)作业:进程管理编程
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
实验1
1[实验题目]
进程的创建控制实验
2[实验目的]
创建进程,体会进程间的并发特征
3[实验内容]
编写一段程序,使用系统调用fork()创建两个子进程p1和p2。而且父进程输出字符串“father”,第一个子进程输出字符串“borther1”,第二个子进程输出字符串“borther2”4[实验要求]
(1)掌握系统调用fork()的使用方法及其功能;
(2)利用系统调用sleep()调整父进程及各子进程的并发执行过程;
(3)认真查看和比较每次执行结果,分析原因。
5[思考问题]
(1)为什么各字符串的输出顺序会是任意的?
(2)改写程序,将字符串用循环语句一个一个字符输出,再查看执行结果如何?
实验2
1[实验题目]
基于管道的进程通信实验
2[实验目的]
创建无名管道,实现基于管道的进程间数据通信,掌握管道通信的方法及特征;并进一步理解互斥与同步的含义。
3[实验内容]
编写一段程序,使用系统调用pipe()创建一无名管道,同时父进程创建一个子进程p1;
并使子进程通过管道向父进程传递数据“p1 process is sending data to father.”,父进程通过管道接收到该字符串后输出。
4[实验要求]
(1)掌握系统调用pipe()的使用方法及其功能,理解管道通信原理;
(2)掌握利用系统调用exit()和wait()实现父进程与子进程之间的同步,理解同步的含义。
5[思考问题]
(1)为什么要在父进程与子进程之间通过管道同步传递数据?不同步而任意写入或读取数据结果如何?
(2)若两个子进程通过管道分别向父进进程传递数据,则如何实现?同时注意查看执行结果,父进程读取各子进程传来的数据顺序如何?(注意各子进程间利用lockf()
加锁互斥向管道写入数据)
实验3
1[实验题目]
进程的软中断通信
(1)理解掌握软中断的概念和技术;
(2)掌握进程之间基于软中断的通信技术。
3[实验内容]
编写一段程序,父进程创建一个子进程p1;并使子进程利用系统调用kill()向父进程发送信号,父进程得到信号后输出字符串“received p1 signal.”。
4[实验要求]
(1)正确应用系统调用signal()建立进程与信号(异步事件)之间的联系,理解信号机制;
(2)正确应用系统调用getppid()、kill(),进步理解广义同步的含义。
5[思考问题]
(1)为什么说系统调用signal()是建立进程与信号之间的联系,而不是接收信号的操作?
(2)若子进程向父进程发送信号,父进程接到信号后可以缺省操作、或忽视信号、或执行一函数,各是什么含义?
实验4
1[实验题目]
进程间基于消息队列的通信
2[实验目的]
系统了解linux系统的通信机构IPC ,掌握IPC中消息通信机制,理解消息通信的方法及特征。
3[实验内容]
编写一段程序,同时父进程创建两个子进程p1和p2;并使子进程p1与子进程p2通过消息队列相互发送消息(512字节)。
4[实验要求]
(1)掌握系统调用msgget()、msgsnd()、msgrev()、msgctl()的使用方法及其功能,理解消息通信原理;
(2)系统理解linux 的三种通信机制。
5[思考问题]
(1)消息通信与管道通信有何区别(进程家族)?
(2)为什么unix中要增设IPC核心软件包?
实验5
1[实验题目]
进程间基于共享存储区的通信
2[实验目的]
系统了解linux系统的通信机构IPC ,掌握IPC中共享存储区通信机制,理解共享存储区通信的方法及特征。
3[实验内容]
编写一段程序,同时父进程创建两个子进程p1和p2;并使子进程p1与子进程p2通过共享存储区相互发送数据(512字节)。
(1)掌握系统调用shmget()、shmat()、shmdt()、shmctl()的使用方法及其功能,理解共享存储区通信原理;
(2)系统理解linux 的三种通信机制。
5[思考问题]
(1)共享存储区与消息通信有何区别?
(2)基于共享存储区通信中的进程间的同步是如何实现的?