操作系统实验3进程间通信

上传人:ning****hua 文档编号:57881773 上传时间:2022-02-25 格式:DOC 页数:4 大小:123.50KB
收藏 版权申诉 举报 下载
操作系统实验3进程间通信_第1页
第1页 / 共4页
操作系统实验3进程间通信_第2页
第2页 / 共4页
操作系统实验3进程间通信_第3页
第3页 / 共4页
资源描述:

《操作系统实验3进程间通信》由会员分享,可在线阅读,更多相关《操作系统实验3进程间通信(4页珍藏版)》请在装配图网上搜索。

1、南昌航空大学实验报告二0一二 年4月22 日课程名称: 操作系统 实验名称: 进程间通信 班级: 090451 姓名: 杨望 学号: 09045131 指导教师评定: 签名: 一、 实验目的 Linux系统的进程通信机构 (IPC) 允许在任意进程间大批量地交换数据。本实验的目的是了解和熟悉Linux支持的消息通讯机制及信息量机制。 二、 实验任务1、消息的创建,发送和接收。 (1)使用系统调用msgget (), msgsnd (), msgrev (), 及msgctl () 编制一长度为1k的消息的发送和接收程序。 (2)观察上面的程序,说明控制消息队列系统调用msgctl () 在此起

2、什么作用?2、共享存储区的创建、附接和段接。 使用系统调用shmget(),shmat(),sgmdt(),shmctl(),编制一个与上述功能相同的程序。3、比较上述(1),(2)两种消息通信机制中数据传输的时间。三、 实验步骤1、消息的创建,发送和接收 程序设计(1) 为了便于操作和观察结果,用一个 程序为“引子”,先后fork( )两个子进 程,SERVER和CLIENT,进行通信。(2) SERVER端建立一个Key为75的消息队列,等待其他进程发来的消息。当遇到类型为1的消息,则作为结束信号,取消该队列,并退出SERVER 。SERVER每接收到一个消息后显示一句“(server)r

3、eceived”。(3) CLIENT端使用Key为75的消息队列,先后发送类型从10到1的消息,然后退出。最后的一个消息,既是 SERVER端需要的结束信号。CLIENT每发送一条消息后显示一句“(client)sent”。(4) 父进程在 SERVER和 CLIENT均退出后结束。程序#include #include #include #include #define MSGKEY 75 /*定义关键词MEGKEY*/struct msgform /*消息结构*/long mtype;char mtexe1030; /*文本长度*/msg;int msgqid,i;void CLIENT

4、( )int i;msgqid=msgget(MSGKEY,0777);for(i=10;i=1;i-) msg.mtype=i; printf(client)sentn); msgsnd(msgqid,&msg,1024,0); /*发送消息msg入msgid消息队列*/exit(0);void SERVER( ) msgqid=msgget(MSGKEY,0777|IPC_CREAT); /*由关键字获得消息队列*/ do msgrcv(msgqid,&msg,1030,0,0); /*从队列msgid接受消息msg*/ printf(server)receiven); while(msg

5、.mtype!=1); /*消息类型为1时,释放队列*/ msgctl(msgqid, IPC_RMID,0); exit(0);main() if(fork() SERVER();else CLIENT( ); wait(0);wait(0);程序执行结果 2、共享存储区的创建,附接和断接 (1)为了便于操作 和观察结果,用一个 程序为“引子”,先后fork( )两个子进程,SERVER 和 CLIENT,进行通信。(2)SERVER端建立一个KEY为75的共享区,并将第一个字节置为-1.作为数据空的标志.等待其他进程发来的消息.当该字节的值发生变化时,表示收到了该消息,进行处理.然后再次把

6、它的值设为-1.如果遇到的值为0,则视为结束信号,取消该队列,并退出SERVER.SERVER每接收到一次数据后显示”(server)received”. (3)CLIENT端建立一个为75的共享区,当共享取得第一个字节为-1时, Server端空闲,可发送请求. CLIENT 随即填入9到0.期间等待Server端再次空闲.进行完这些操作后, CLIENT 退出. CLIENT每发送一次数据后显示”(client)sent”. (4)父进程在SERVER和CLIENT均退出后结束.#include#include#include#define SHMKEY 75 /*定义共享区关键词*/in

7、t shmid,i;int *addr; CLIENT()int i;shmid=shmget(SHMKEY,1024,0777); addr=shmat(shmid,0,0); /*共享区起始地址为addr*/for(i=9;i=0;i-) while(*addr!= -1); printf(client)sentn); /*打印(client)sent*/*addr=i; /*把i赋给addr*/exit(0); SERVER()shmid=shmget(SHMKEY,1024,0777|IPC_CREAT); /*创建共享区*/addr=shmat(shmid,0,0); /*共享区起始

8、地址为addr*/do*addr=-1;while(*addr=-1);printf(server)receivedn); /*服务进程使用共享区*/ while(*addr);shmctl(shmid,IPC_RMID,0);exit(0); main()if(fork()SERVER();if(fork()CLIENT();wait(0);wait(0);程序执行结果:3 、比较两种消息通信机制中的数据传输的时间 由于两种机制实现的机理和用处都不一样,难以直接进行时间上的比较。如果比较其性能,应更加全面的分析。(1)消息队列的建立比共享区的设立消耗的资源少.前者只是一个软件上设定的问题,后

9、者需要对硬件操作,实现内存的映像,当然控制起来比前者复杂.如果每次都重新进行队列或共享的建立,共享区的设立没有什么优势。(2)当消息队列和共享区建立好后,共享区的数据传输,受到了系统硬件的支持,不耗费多余的资源;而消息传递,由软件进行控制和实现,需要消耗一定的CPU资源.从这个意义上讲,共享区更适合频繁和大量的数据传输.(3)消息的传递,自身就带有同步的控制.当等到消息的时候,进程进入睡眠状态,不再消耗CPU资源.而共享队列如果不借助其他机制进行同步,接受数据的一方必须进行不断的查询,白白浪费了大量的CPU资源.可见消息方式的使用更加灵活.四、实验体会本次实验是关于系统进程通信的,通过本次实验实践了课堂的理论知识,进一步了解了进程的概念,熟悉了linux系统调用函数如msgget (), msgsnd (), msgrev (), 及msgctl ()等。当然,对linux系统的操作还不能想windows环境下那么熟悉,所以实验的几项内容没能很仔细的理解操作,还需要进一步的加强学习。4

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

copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!