欢迎来到天天文库
浏览记录
ID:56924775
大小:112.00 KB
页数:9页
时间:2020-07-24
《生产者消费者实验报告.答案.doc》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库。
1、南昌大学实验报告学生姓名:倪焕学号:专业班级:软件工程141班实验类型:■验证□综合□设计□创新实验日期:2016.5.24实验成绩:一、实验项目名称哲学家就餐问题二、实验目的利用PV操作解决生产者消费者问题三、软硬件环境软件:VisualStudio2010硬件:PC机一台四、实验内容结果一、实现代码3个生产者1个消费者,生产者会等待消费者#include#includeconstunsignedshortSIZE_OF_BUFFER=10;//缓冲区长度unsignedshortProductID=0;/
2、/产品号unsignedshortConsumeID=0;//将被消耗的产品号unsignedshortin=0;//产品进缓冲区时的缓冲区下标unsignedshortout=0;//产品出缓冲区时的缓冲区下标intg_buffer[SIZE_OF_BUFFER];//缓冲区是个循环队列boolg_continue=true;//控制程序结束HANDLEg_hMutex;//用于线程间的互斥HANDLEg_hFullSemaphore;//当缓冲区满时迫使生产者等待HANDLEg_hEmptySemaphore;//当缓冲区空时迫使消费者等待DWO
3、RDWINAPIProducer(LPVOID);//生产者线程DWORDWINAPIConsumer(LPVOID);//消费者线程intmain(){//创建各个互斥信号g_hMutex=CreateMutex(NULL,FALSE,NULL);g_hFullSemaphore=CreateSemaphore(NULL,SIZE_OF_BUFFER-1,SIZE_OF_BUFFER-1,NULL);g_hEmptySemaphore=CreateSemaphore(NULL,0,SIZE_OF_BUFFER-1,NULL);//调整下面的数值,可
4、以发现,当生产者个数多于消费者个数时,//生产速度快,生产者经常等待消费者;反之,消费者经常等待constunsignedshortPRODUCERS_COUNT=3;//生产者的个数constunsignedshortCONSUMERS_COUNT=1;//消费者的个数//总的线程数constunsignedshortTHREADS_COUNT=PRODUCERS_COUNT+CONSUMERS_COUNT;HANDLEhThreads[PRODUCERS_COUNT];//各线程的handleDWORDproducerID[CONSUMERS_C
5、OUNT];//生产者线程的标识符DWORDconsumerID[THREADS_COUNT];//消费者线程的标识符//创建生产者线程for(inti=0;i6、ad(NULL,0,Consumer,NULL,0,&consumerID[i]);if(hThreads[i]==NULL)return-1;}while(g_continue){if(getchar()){//按回车后终止程序运行g_continue=false;}}return0;}//生产一个产品。简单模拟了一下,仅输出新产品的ID号voidProduce(){std::cerr<<"Producing"<<++ProductID<<"...";std::cerr<<"Succeed"<7、idAppend(){std::cerr<<"Appendingaproduct...";g_buffer[in]=ProductID;in=(in+1)%SIZE_OF_BUFFER;std::cerr<<"Succeed"<8、;}}//从缓冲区中取出一个产品voidTake(){std::cerr<<"Takingaproduct.
6、ad(NULL,0,Consumer,NULL,0,&consumerID[i]);if(hThreads[i]==NULL)return-1;}while(g_continue){if(getchar()){//按回车后终止程序运行g_continue=false;}}return0;}//生产一个产品。简单模拟了一下,仅输出新产品的ID号voidProduce(){std::cerr<<"Producing"<<++ProductID<<"...";std::cerr<<"Succeed"<7、idAppend(){std::cerr<<"Appendingaproduct...";g_buffer[in]=ProductID;in=(in+1)%SIZE_OF_BUFFER;std::cerr<<"Succeed"<8、;}}//从缓冲区中取出一个产品voidTake(){std::cerr<<"Takingaproduct.
7、idAppend(){std::cerr<<"Appendingaproduct...";g_buffer[in]=ProductID;in=(in+1)%SIZE_OF_BUFFER;std::cerr<<"Succeed"<8、;}}//从缓冲区中取出一个产品voidTake(){std::cerr<<"Takingaproduct.
8、;}}//从缓冲区中取出一个产品voidTake(){std::cerr<<"Takingaproduct.
此文档下载收益归作者所有