进程的共享存储区通信--带答案版_第1页
进程的共享存储区通信--带答案版_第2页
进程的共享存储区通信--带答案版_第3页
进程的共享存储区通信--带答案版_第4页
全文预览已结束

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、实验二进程管理2.4进程的共享存储区通信1. 实验目的(1)通过编写共享存储区的通信程序,理解Linux共享存储区机制。(2) 掌握进程共享存储区通信相关系统调用。(3) 理解系统调用和用户命令的区别。2. 实验类型:验证型3. 实验学时: 24. 实验原理和知识点(1) 实验原理:并发运行的进程之间,可以通过共享存储机制进行通信。(2) 知识点:共享存储的创建、附接和断接5. 实验环境(硬件环境、软件环境):(1)硬件环境:Intel Pentium III以上CPU, 128MB以上内存,2GB 以上硬盘(2) 软件环境: linux 操作系统。6.预备知识(1)共享存储区共享存储区机制直

2、接通过共享虚拟存储空间进行通信。 通信时, 进程首先提出申请, 系统为之分配存储空间并返回共享区标示符。 这时, 进程把它附加到自己的虚拟存储空间中。 通信的进程对共享区的访问要互斥地进行。(2) shmget()系统调用:头文件 #include <sys/shm.h>函数原型 int shmget(key_t key, int size, int flag);功能:申请一个共享存储区。成功返回共享内存标识符,失败则返回-1 。参数: key是共享存储区关键字。size 是存储区大小。 flag访问权限和控制标志。(3) shmat()系统调用:头文件 #include <

3、sys/shm.h>函数原型 int shmat(int id, char *addr, int flag);功能:将一个共享存储区附接到进程的虚地址空间。成功返回起始地址,失败则返回-1 。数: id 是共享存储区标识符。addr 是附接的虚地址。 flag访问权限和控制标志。(4) shmdt()系统调用:头文件 #include <sys/shm.h>函数原型int shmdt(char *addr);功能:一个共享存储区与指定进程的断开。1(5) shmctl()系统调用:头文件 #include <sys/shm.h>函数原型int shmctl(int

4、 id, int cmd, struct_ds* buf;功能:共享存储区的控制操作。成功返回0 ,失败则返回-1 。参数: id是共享存储区标识符。cmd 为 IPC_STAT共享存储的区的控制信息块读入buf 。 cmd为 IPC_SET 则共享存储区的控制信息块读入 buf 。 cmd 为 IPC_RMID则删除 shmid 指示的共享内存。7. 实验内容及步骤:【任务】使用系统调用shmget()、 shmat()、 shmdt()、 shmctl(),编写两进程通过共享存储区进行通信的程序。(1) 程序设计约定共享区关键字75。创建两个子进程client和 server。Client

5、发送10 条消息。Server接收消息 , 完毕后删除共享区。/ share.c#include <sys/types.h>#include <sys/msg.h>#include <sys/ipc.h>#include <stdio.h>#define SHMKEY 75/*定义共享存储区关键词*/int shmid,i;int *addr;void Client() int i;shmid=shmget(SHMKEY,1024,0777)addr=(int*)shmat(shmid,0,0); /*; /*获取共享区 ,长度 1024,共享区

6、的起始地址为关键词为 addr */SHMKEY */for(i=9;i>=0;i-) while(*addr!=-1);/*printf(client %d)sentn,i); /*addr=i;/*在这里做一个标号A */打印 (client) sent */把 i赋给 addr所指向的区域*/exit(0);void Server() shmid=shmget(SHMKEY,1024,0777|IPC_CREAT); /*addr=(int*)shmat(shmid,0,0); /*共享区的起始地址为do *addr=-1;创建共享区addr */*/2while(*addr=-1);/*printf(server %d)received!n,*addr); /*等待发来信息,转到上面的标号A; */服务进程使用共享区*/while(*addr);shmctl(shmid,IPC_RMID,0);exit(0);int main() int i; while(i=fork()=-1); if(!i) Server();else while(i=fork()=-1); if(!i) Client();wait(0

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论