实验四进程间通信实验(一)

实验四进程间通信实验(一)

ID:41661049

大小:62.79 KB

页数:9页

时间:2019-08-29

实验四进程间通信实验(一)_第1页
实验四进程间通信实验(一)_第2页
实验四进程间通信实验(一)_第3页
实验四进程间通信实验(一)_第4页
实验四进程间通信实验(一)_第5页
资源描述:

《实验四进程间通信实验(一)》由会员上传分享,免费在线阅读,更多相关内容在工程资料-天天文库

1、实验四进程间通信实验(一)实验目的:1.通过基础实验,基本学握共享内存的程序设计。2.通过编写程序,使读者掌握消息队列的设计方法。实验内容:1.共享内存程序设计:创建两个进程,在A进程屮创建一个共享内存,并向其写入数据,通过B进程从共亨内存中读出数据。2.消息队列程序设计:创建一个消息队列,如何使用消息队列进行两个进程(发送端和接受端)Z间的通信,包括消息队列的创建、消息发送与读取、消息队列的撤销和删除等多种操作。实验过程:(-)共享内存程序设计►函数说明:共享内存的实现分为两个步骤,第…步是创建共享内存,这里用到的函数是shmget(),也就

2、是从内存中获得一段共享内存区域。第一步映射共享内存,也就是把这段创建的共享内存映射到具体的进程空间中,这里使用的函数是shmatOo到这里,就可以使用这段共享内存了,也就是可以使用不带缓冲的I/O读写命令对其进行操作。除此Z外,当然还有撤销映射的操作,其函数为shmdtOo►共享内存的用法:使用共享内存进行进程间通信-•般要经历下而儿个步骤:[1]分配:进程通过调用shmget来分配一个共享内存块。12J映射:要让一个进程获取对一块共享内存的访问,这个进程必须先调川shmat映射共享内存。[3]脱离与释放:当进程结束使用共亨内存时,使用shmd

3、t使共亨内存脱离进程。当不再需要共享内存时,使用shmctl(sid,IPC_RMID,0)删除它。实验步骤及代码:1)自己建立文件夹,然后分别编辑shm_com・h、shml.c、shm2.c.[root@localhostbyy]#vishm_coin.h[root@localhostbyy]#vishml.c[root@localhostbyy]#cpshml.cshm2.c[root@localhostbyy]#vishm2.c/*shmcom.h*/#defineTEXT_SZ2048structshared_use_st{intwr

4、itten_by_you;charsome_text[TEXT_SZ];};功能描述:本程序申请和分配共享内存,然后轮询并读取共享内存中的数据,直至读到“end”/*shml.c*/#include#includeh>#include#include#include#includeh>#includeh>#includenshm_coniehf,intmain(void){intrunning=l;void*s

5、hared_memory=(void*)0;structsharedusest^sharedstuff;intshmid;八创建共享内存旬shniid=shmget((key_t)12349sizeof(structshared_use_st),0666IIPC_CREAT);if(shmid==-l){fprintf(stderr,nshingetfailedn);exit(EXIT_FAILURE);}/*映射共享内存*/shared_memory=shmat(shmid,(void*)0,0);if(shared_memory==(v

6、oid*)-1){fprintf(stdeir,''shmatfailedXn”);exit(EX!T_FAILURE);}printf(uMemoryattachedat%X,,,(int)shared_memory);八让结构体指针指向这块共享内存引shared_stuff=(structshared_use_st*)shared_memory;严控制读写顺序*/shared_stuff->written_by_you=();八循环地从共享内存中读数据,直到读到“end”为止*/while(runiiing)if(shared_stuf

7、f->written_by_you){printf(HYouwrote:%sn,shared_stuff->some_text);/*读进程睡眠1秒,同时会导致写进程睡眠1秒,做到先读后写旬sleep⑴;shared_stuff->written_by_you=0;if(strncmp(shared_stuff->some_text/tendt3)==0){runnin沪0;//结束循环八删除共享内存*/if(shmdt(shared_memory)==-l){fprintf(stderr,Hshmdtfailedn);exit(EXIT

8、_FAILURE);}exit(EXIT_SUCCESS);功能描述:本程序申请了上一段程序相同的共享内存,然后循环地向共享内存中写数据,直至写入“e

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

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

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