操作系统编程消费者生产者模拟.docxVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
#include stdafx?h include windows?h include stdio. h include stdlib. h include string? h inelude time.h ^pragma warn ing(disablc:4996) PROCESS_IXFORMATION StartClonc(int nCloncID); int index = 0; 〃申请的缓冲区,以数组形式,大小为三,长度为10 struct SHM int read: int write; ch吐 buf[4][10]{ }; //得到一个随机数 int gct_random() { int number; number 二 rand() % 3000; return number; } int get_ letter () { int number; srand((unsigned)(time(XILL))); number = rancl() % 3; return number; } int main(int argc, char* argv[]) { srand((unsigned)(time(NULL))); int nClone = 0; int i, time, j, 1, z; int 1t; char tt, ts[10]; HANDLE SEM FULL; HANDLE SEM EMPTY: HANDLE SEM_MUTEX; HANDLE hMap; PROCESS INFORMATION nH[7]; struct SHM *shm; if (argc 1) sscanf_s(argv[叮,%d, nClone) :// 从第二个参数中提取克隆ID if (nClone二二0) //主进程,创建7个子进程,前3个为生产者,后4个为消费者 { printfC主进程开始执行\『); //建立信号量 SEM FULL = CreateSemaphore(NULL, 0, 4, FULL); SEM_EMPTY = GreateSemaphoreOJULL, 4, 4, EMPTY); SEM_MUTEX = CreateSemaphoreOJULL, 1, 1, MUTEX); HANDLE CurrcntProccss = GctCurrcntProccss0 ;//建立共享内存 hMap 二 CreateF订eMapping 仃NVALID_HA\DLE_VALl:E, NULL, PAGE_READWRITE, 0, sizeof仕shm), buffer); //该文件映射的作为共享内存的缓冲区,取名为buffer 〃在文件映射上创建视图 LPVOID pData = MapViewOfFile (hMap, FILE_\IAP_WRITE, 0, 0, sizeof (*shm)); if (pData != NULL) { ZeroMcmory (pData, sizeof (shm)): //分配内〃空间,并清零 } hMap = OpenF订eMapping(FILE_\IAP_WRITE, FALSE, buffer); shm = (struct SHM*)MapViewOfFi1e(hMap, FILE_MAP_WRTTE, 0, 0, sizeof(*shm)); for (i = 0; i 4; i++) { strcpy(shm-buf[shm-write],; shm-〉write = (shm-write + 1) % 4; } //建立7个子进程 for (i = 0; i7; i++) { nH[i]二 StartClone(++nClone); } 〃等待子进程结束 for (i = 0; i7; i++) WaitForSingleObject(nH[i]. hProcess, INFINITE); //关闭子进程句柄 for (i = 0; i7; i++) CloseHandle(nH[i]. hProcess); Closellandle(nll[ij. hThread); //关闭句柄 CloseHandle(SEM_MUTEX); CloseHandle(hMap); Closellandle(SEM EMPTY); CloseHandle(SEM_FILL); } else if (nClone 0 nClone 4) //3个主产者 { //获得句柄 );); ); ); sizcof(*shm)); SEM FULL = OpenSemaphore (SEMAPHORE ALL ACCESS, NULL, FULL) SEMJILT

您可能关注的文档

文档评论(0)

ggkkppp + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档