写者问题实验报告 - 找源代码、程序员

写者问题实验报告 - 找源代码、程序员

ID:12703984

大小:131.50 KB

页数:15页

时间:2018-07-18

写者问题实验报告 - 找源代码、程序员_第1页
写者问题实验报告 - 找源代码、程序员_第2页
写者问题实验报告 - 找源代码、程序员_第3页
写者问题实验报告 - 找源代码、程序员_第4页
写者问题实验报告 - 找源代码、程序员_第5页
资源描述:

《写者问题实验报告 - 找源代码、程序员》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、1读者/写者问题实验报告――多线程的实现信息科学与技术学院计算机科学系一、实验要求在Windows2000/XP环境下,创建一个控制台进程,此进程包含n个线程。用这n个线程来表示n个读者或写者。每个线程按相应测试数据文件(格式见下)的要求进行读写操作。用信号量机制分别实现读者优先和写者优先的读者/写者问题。运行结果显示要求:要求在每个线程创建、发出读写操作申请、开始读写操作和结束读写操作时分别显示一行提示信息,以确定所有处理都遵守相应的读写操作限制。测试数据文件格式如下:测试数据文件包括n行测试数据,分别

2、描述创建的n个线程是读者还是写者,以及读写操作的开始时间和持续时间。每行测试数据包括4个字段,各个字段间用空格分隔。?第一个字段为一个正整数,表示线程序号?第二个字段表示相应线程角色,R表示读者,W表示写者?第三个字段为一个正数,表示读/写操作的开始时间:线程创建后,延迟相应时间(单位为秒)后发出对共享资源的读/写请求?第四个字段为一正数,表示读/写操作的持续时间:线程读写请求成功后,开始对共享资源的读/写操作,该操作持续相应时间后结束,并释放共享资源例如:1R352W453R524R655W5.13二、

3、实验理解分析与设计1.进程和线程在Windows32位操作系统中,所谓多任务是指系统可以同时运行多个进程,而每个进程也可以同时执行多个线程。所谓进程就是应用程序的运行实例。每个进程都有自己私有的虚拟地址空间。每个进程都有一个主线程,但可以建立另外的线程。进程中的线程是并发执行的,每个线程占用CPU的时间由系统来划分。我们可以把线程看成是操作系统分配CPU时间的基本实体。进程中的所有线程共享进程的虚拟地址空间,这意味着所有线程都可以访问进程的全局2变量和资源。这一方面为编程带来了方便,但另一方面也容易造成冲

4、突。虽然在进程中进行费时的工作不会导致系统的挂起,但这会导致进程本身的挂起。所以,如果进程既要进行长期的工作,又要响应用户的输入,那么它可以启动一个线程来专门负责费时的工作,而主线程仍然可以与用户进行交互。2.线程的同步多线程的使用会产生一些新的问题,主要是如何保证线程的同步执行。多线程应用程序需要使用同步对象和等待函数来实现同步。同步问题是实现远程数据采集或远程自动控制编程中的关键技术问题。3.同步的原因由于同一进程的所有线程共享进程的虚拟地址空间,并且线程的中断是汇编语言级的,所以可能会发生两个线程同

5、时访问同一个对象(包括全局变量、共享资源、API函数和MFC对象等)的情况,这有可能导致程序错误。例如,如果一个线程在未完成对某一大尺寸全局变量的读操作时,另一个线程又对该变量进行了写操作,那么第一个线程读入的变量值可能是一种修改过程中的不稳定值。属于不同进程的线程在同时访问同一内存区域或共享资源时,也会存在同样的问题。因此,在多线程应用程序中,常常需要采取一些措施来同步线程的执行。4.同步的方法由于线程间需要同步机制,才能协调运行。在Windows32编程中,主要提供了以下几种方法。等待函数这些函数只有

6、在作为其参数的一个或多个同步对象产生信号时才会返回。在超过规定的等待时间后,不管有无信号,函数也都会返回。在等待函数未返回时,线程处于等待状态,此时线程只消耗很少的CPU时间。使用等待函数即可以保证线程的同步,又可以提高程序的运行效率。最常用的等待函数是WaitForSingleObject,该函数的声明为:DWORDWaitForSingleObject(HANDLEhHandle,DWORDdwMilliseconds);参数hHandle是同步对象的句柄。参数dwMilliseconds是以毫秒为单

7、位的超时间隔,如果该参数为0,那么函数就测试同步对象的状态并立即返回,如果该参数为INFINITE,则超时间隔是无限的。同步对象同步对象用来协调多线程的执行,它可以被多个线程共享。线程的等待函数用同步对象的句柄作为参数,同步对象应该是所有要使用的线程都能访问到的。同步对象的状态要么是有信号的,要么是无信号的。同步对象主要有三种:事件、mutex和信号灯。?事件对象(Event)是最简单的同步对象,它包括有信号和无信号两种状态。在线程访3问某一资源之前,也许需要等待某一事件的发生,这时用事件对象最合适。例如

8、,只有在通信端口缓冲区收到数据后,监视线程才被激活。?Mutex对象的状态在它不被任何线程拥有时是有信号的,而当它被拥有时则是无信号的。mutex对象很适合用来协调多个线程对共享资源的互斥访问(mutuallyexclusive)。?信号灯对象维护一个从0开始的计数,在计数值大于0时对象是有信号的,而在计数值为0时则是无信号的。信号灯对象可用来限制对共享资源进行访问的线程数量。线程用CreateSemaphore函数来建立信号

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。