欢迎来到天天文库
浏览记录
ID:20378844
大小:123.50 KB
页数:9页
时间:2018-10-11
《实验四 进程间通信实验(一)》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库。
1、实验四进程间通信实验(一)实验目的:1.通过基础实验,基本掌握共享内存的程序设计。2.通过编写程序,使读者掌握消息队列的设计方法。实验内容:1.共享内存程序设计:创建两个进程,在A进程中创建一个共享内存,并向其写入数据,通过B进程从共享内存中读出数据。2.消息队列程序设计:创建一个消息队列,如何使用消息队列进行两个进程(发送端和接受端)之间的通信,包括消息队列的创建、消息发送与读取、消息队列的撤销和删除等多种操作。实验过程:(一)共享内存程序设计}函数说明:共享内存的实现分为两个步骤,第一步是创建共享内存,
2、这里用到的函数是shmget(),也就是从内存中获得一段共享内存区域。第二步映射共享内存,也就是把这段创建的共享内存映射到具体的进程空间中,这里使用的函数是shmat()。到这里,就可以使用这段共享内存了,也就是可以使用不带缓冲的I/O读写命令对其进行操作。除此之外,当然还有撤销映射的操作,其函数为shmdt()。}共享内存的用法:使用共享内存进行进程间通信一般要经历下面几个步骤:[1]分配:进程通过调用shmget来分配一个共享内存块。[2]映射:要让一个进程获取对一块共享内存的访问,这个进程必须先调用s
3、hmat映射共享内存。[3]脱离与释放:当进程结束使用共享内存时,使用shmdt使共享内存脱离进程。当不再需要共享内存时,使用shmctl(sid,IPC_RMID,0)删除它。实验步骤及代码:1)自己建立文件夹,然后分别编辑shm_com.h、shm1.c、shm2.c./*shm_com.h*/#defineTEXT_SZ2048structshared_use_st{intwritten_by_you;charsome_text[TEXT_SZ];};-------------------------
4、-------------------------------------------------------------------------------------------功能描述:本程序申请和分配共享内存,然后轮询并读取共享内存中的数据,直至读到“end”/*shm1.c*/#include#include#include#include#include#include#
5、include#include"shm_com.h"intmain(void){intrunning=1;void*shared_memory=(void*)0;structshared_use_st*shared_stuff;intshmid;/*创建共享内存*/shmid=shmget((key_t)1234,sizeof(structshared_use_st),0666
6、IPC_CREAT);if(shmid==-1){fprintf(stderr,"shmgetfailed
7、n");exit(EXIT_FAILURE);}/*映射共享内存*/shared_memory=shmat(shmid,(void*)0,0);if(shared_memory==(void*)-1){fprintf(stderr,"shmatfailed");exit(EXIT_FAILURE);}printf("Memoryattachedat%X",(int)shared_memory);/*让结构体指针指向这块共享内存*/shared_stuff=(structshared_use_st*)
8、shared_memory;/*控制读写顺序*/shared_stuff->written_by_you=0;/*循环地从共享内存中读数据,直到读到“end”为止*/while(running){if(shared_stuff->written_by_you){printf("Youwrote:%s",shared_stuff->some_text);/*读进程睡眠1秒,同时会导致写进程睡眠1秒,做到先读后写*/sleep(1);shared_stuff->written_by_you=0;if(strnc
9、mp(shared_stuff->some_text,"end",3)==0){running=0;//结束循环}}}/*删除共享内存*/if(shmdt(shared_memory)==-1){fprintf(stderr,"shmdtfailed");exit(EXIT_FAILURE);}exit(EXIT_SUCCESS);}--------------------------------------
此文档下载收益归作者所有