欢迎来到天天文库
浏览记录
ID:51746457
大小:1.03 MB
页数:8页
时间:2020-03-15
《操作系统实验一进程与线程—Linux进程与线程通讯实验报告.doc》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库。
1、操作系统课程设计任务书实验题目:实验一:进程与线程—Linux进程与线程通讯实验目的:深刻理解线程与进程的概念,掌握进程与线程在组成成分上的差别以及与其相适应的通讯方式和应用目标。实验内容:以Linux系统进程和线程机制为背景,掌握fork()和clone()系统调用的形式和功能以及与其相适应的高级通讯方式。有fork派生的子进程之间通过pipe通讯,由clone创建的线程之间通过共享内存通讯,对于后者需要考虑互斥问题。以生产者–消费者问题为例,通过实验理解fork()和clone()两个系统调用的区别
2、。程序要求能够创建4个进程或线程,其中包括两个生产者和两个消费者,生产者和消费者之间能够传递数据。设计准备:(理论技术)1.什么是进程?进程是具有一定独立功能的程序关于一个数据集合的一次运行活动。2.什么是线程?线程是进程内的一个相对独立的执行流。3.线程是与其父进程具有相同地址空间的进程。4.进程与线程的差别通过与fork不同的另一个系统调用clone体现出来。fork为子进程创建一个具有全新上下文的独立的地址空间,而clone并不产生新的地址空间,子进程共享父进程的地址空间。Clone为应用程序提供
3、了细粒度的共享成分控制。5.Linux中的进程包含3个段,数据段,代码段,堆栈段。6.fork()函数用于从已存在的进程中创建一个新进程,新进程称为子程,而原进程称为父进程。使用fork()函数,子进程从父进程处继承了整个进程的地址空间。而子进程独有的只有它的进程号,资源使用和计时器等。7.Fork()函数语法要点:①所需头文件:#include//提供类型pid_t的定义;#include②函数原型:pid_tfork(void)③函数返回值:0:子程序;
4、子进程ID(大于0的整数):父进程;-1:出错。8.8实验步骤:1.安装虚拟机,并安装虚拟Linux系统,实现Linux联网2.在ftp://202.116.102.7上下载OS文件夹,保存在终端3.打开终端,运行一下代码Cdosgcctest_fork.c–oforkls./fork(运行fork())gcc–lpthreadtest_clone.c–oclone./clone(运行clone())4.分析实验代码,与实验代码对比,弄懂其中的原理5.实验结束,保存系统,退出Linux系统实验结果:./
5、fork输出结果:./clone输出结果:88实验讨论:由程序1结果可知,使用 fork()语句创建的子进程与其父进程具有相对独立的地址空间,在此解决生产者-消费者问题里,可以采用pipe()进行通讯。子进程复制了父进程的打开文件表,所以pipe()所建立的通信管道可被子进程继承,生产和消费进程可以通过对同一通信管道文件的读书进行通讯。由程序2结果可知:clone()语句在创建进程时,可通过参数设定子进程与父进程是否共享存储空间,从而可以创建真正意义上的程序。生产者和消费者进程共享内在,从而可以通过共享
6、交换数据。但多个进程共享共存需要互斥机制。三.实验流程图程序二流程图:基于clone()系统调用父进程:生产者子进程(Producer):8消费者子进程(Consumer):8基于fork()系统调用的流程图:主程序:8生产者进程:(producer)消费者进程:(consumer)88
此文档下载收益归作者所有