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

  • 75
  • 0
  • 约7.01千字
  • 约 9页
  • 2016-11-27 发布于河南
  • 举报
实验四 进程间通信实验(一)

实验四 进程间通信实验(一) 实验目的: 通过基础实验,基本掌握共享内存的程序设计。 通过编写程序,使读者掌握消息队列的设计方法。 实验内容: 共享内存程序设计:创建两个进程,在A进程中创建一个共享内存,并向其写入数据,通过B进程从共享内存中读出数据。 消息队列程序设计:创建一个消息队列,如何使用消息队列进行两个进程(发送端和接受端)之间的通信,包括消息队列的创建、消息发送与读取、消息队列的撤销和删除等多种操作。 实验过程: (一)共享内存程序设计 函数说明:共享内存的实现分为两个步骤,第一步是创建共享内存,这里用到的函数是shmget(),也就是从内存中获得一段共享内存区域。第二步映射共享内存,也就是把这段创建的共享内存映射到具体的进程空间中,这里使用的函数是shmat()。到这里,就可以使用这段共享内存了,也就是可以使用不带缓冲的I/O读写命令对其进行操作。除此之外,当然还有撤销映射的操作,其函数为shmdt()。 共享内存的用法:使用共享内存进行进程间通信一般要经历下面几个步骤: 分配:进程通过调用shmget来分配一个共享内存块。 映射:要让一个进程获取对一块共享内存的访问,这个进程必须先调用shmat映射共享内存。 脱离与释放:当进程结束使用共享内存时,使用shmdt使共享内存脱离进程。当不再需要共享内存时,使用shmctl(sid,IPC_RMID,0)删除它。 实验步骤及代码: 1)自己建立文件夹,然后分别编辑shm_com.h、shm1.c、shm2.c. /*shm_com.h*/ #define TEXT_SZ 2048 struct shared_use_st { int written_by_you; char some_text[TEXT_SZ]; }; ---------------------------------------------------------- ---------------------------------------------------------- 功能描述:本程序申请和分配共享内存,然后轮询并读取共享内存中的数据,直至读到“end” /*shm1.c*/ #includeunistd.h #includestdio.h #includestdlib.h #includestring.h #includesys/types.h #includesys/ipc.h #includesys/shm.h #include shm_com.h int main(void) { int running=1; void *shared_memory=(void *)0; struct shared_use_st *shared_stuff; int shmid; /*创建共享内存*/ shmid=shmget((key_t) 1234,sizeof(struct shared_use_st), 0666|IPC_CREAT); if(shmid==-1) { fprintf(stderr,shmget failed\n); exit(EXIT_FAILURE); } /*映射共享内存*/ shared_memory=shmat(shmid,(void *)0,0); if(shared_memory==(void *)-1) { fprintf(stderr,shmat failed\n); exit(EXIT_FAILURE); } printf(Memory attached at %X\n,(int)shared_memory); /*让结构体指针指向这块共享内存*/ shared_stuff=(struct shared_use_st *)shared_memory; /*控制读写顺序*/ shared_stuff-written_by_you=0; /*循环地从共享内存中读数据,直到读到“end”为止*/ while(running)

文档评论(0)

1亿VIP精品文档

相关文档