




下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
进程间通信实验报告班级:10网工三班学生姓名:谢昊天学号:实验目的和规定:Linux系统的进程通信机构(IPC)允许在任意进程间大批量地互换数据。本实验的目的是了解和熟悉Linux支持的消息通讯机制及信息量机制。实验内容与分析设计:(1)消息的创建,发送和接受。①使用系统调用msgget(),msgsnd(),msgrev(),及msgc11()编制一长度为Ik的消息的发送和接受程序。②观测上面的程序,说明控制消息队列系统调用msgctl()在此起什么作用?(2)共享存储区的创建、附接和段接。使用系统调用shmget(),shmat(),sgmdt(),shmctl(),编制一个与上述功能相同的程序。(3)比较上述(1),(2)两种消息通信机制中数据传输的时间。实验环节与调试过程:.消息的创建,发送和接受:(1)先后通过fork()两个子进程,SERVER和CLIENT进行通信。(2)在SERVER端建立一个Key为75的消息队列,等待其他进程发来的消息。当碰到类型为I的消息,则作为结束信号,取消该队列,并退出SERVERoSERVER每接受到一个消息后显示一句“(servcr)reccived"。(3)CLIENT端使用Key为75的消息队歹人先后发送类型从10到1的消息,然后退出。最后的一个消息,既是SERVER端需要的结束信号。CLIENT每发送一条消息后显示一句”(client)seni”。(4)父进程在SERVER和CLIENT均退出后结束。.共享存储区的创建,附接和断接:(1)先后通过fork()两个子进程,SERVER和CLIENT进行通信。(2)SERVER端建立一个KEY为75的共享区,并将第一个字节置为-1。作为数据空的标志.等待其他进程发来的消息.当该字节的值发生变化时,表达收到了该消息,进行解决.然后再次把它的值设为一I.假如碰到的值为0,则视为结束信号,取消该队歹IJ,并退出SERVER.SERVER每接受到一次数据后显示“(server)received”.(3)CLIENT端建立一个为75的共享区,当共享取得第一个字节为一1时,Server端空闲,可发送请求.CLIENT随即填入9到0.期间等待Server端再次空闲.进行完这些操作后,CLIENT退出.CLIENT每发送一次数据后显示“(c1ient)sent”.(4)父进程在SERVER和CLIENT均退出后结束。实验结果:.消息的创建,发送和接受:由Client发送两条消息,然后Scrvcr接受一条消息。此后ClientServcr交替发送和接受消息。最后一次接受两条消息。Client和Server分别发送和接受了10条消息。message的传送和控制并不保证完全同步,当•个程序不再激活状态的时候,它完全也许继续睡眠,导致上面现象。在多次sendmessage后才receivemessage.这一点有助于理解消息转送的实现机理。.共享存储区的创建,附接和断接:在运营的过程中,发现每当client发送一次数据后,server要等大约0.1秒才有响应。同样,之后client又需要等待大约0.1秒才发送下一个数据。出现上述的应答延迟的现象是程序设计的问题。当clienl端发送了数据后,并没有任何措施告知server端数据已经发出,需要由c1ient的查询才干感知。此时,client端并没有放弃系统的控制权,仍然占用CPU的时间片。只有当系统进行调度时,切换到了server进程,再进行应答。这个问题,也同样存在于server端到client的应答过程之中。3比较两种消息通信机制中的数据传输的时间:由于两种机制实现的机理和用处都不同样,难以直接进行时间上的比较。假如比较其性能,应更加全面的分析。(1)消息队列的建立比共享区的设立消耗的资源少.前者只是一个软件上设定的问题,后者需要对硬件操作,实现内存的映像,当然控制起来比前者复杂.假如每次都重新进行队列或共享的建立,共享区的设立没有什么优势。⑵当消息队列和共享区建立好后,共享区的数据传输,受到了系统硬件的支持,不花费多余的资源;而消息传递,由软件进行控制和实现,需要消耗•定的CPU资源.从这个意义上讲,共享区更适合频繁和大量的数据传输。⑶消息的传递,自身就带有同步的控制.当等到消息的时候,进程进入睡眠状态,不再消耗CPU资源.而共享队列假如不借助其他机制进行同步,接受数据的一方必须进行不断的查询旧白浪费了大量的CPU资源.可见消息方式的使用更加灵活。疑难小结:通过本次实验让我了解了进程间通信,message的传送和控制并不保证完全同步,当一个程序不再激活状态的时候,它完全也许继续睡眠,在多次sendmessage后才receivemessage.这一点有助于理解消息转送的实现机理。并且了解了只有当系统进行调度时,切换到了server进程,再进行应答。这个问题,也同样存在于server端到client的应答过程之中。加深了对进程概念的理解,明确进程间通信的原理,进一步结识并发执行的实质。巩固了课本上所学到的知识。重要算法和程序清单:1.消息的创建,发送和接受:include<stdio.h>inelude<sys/types.h>include<sys/msg.h>inc1ude<sys/ipc.h>
#defineMSGKEY75/*定义关键词MEGKEY*/#defineMSGKEY75/*定义关键词MEGKEY*/Iongmtype;«charmtexc[100]:}msg;/*消息结构*//火文本长度*/intmsgqidj:voidCLIENT()/*消息结构*//火文本长度*/inti;msgqid=msgget(MSGKEY,0777IIPC_CREAT);for(i=10;i>=l;i-)®{。msg.mtype=i;printf(*'(c1ient)sent\n");gmsgsnd(msgqid,&msg,1030,0);/*发送消息msg入msgid消息队列文/exit(0);)voidSERVER()(msgqid=msgget(MSGKEY0777|IPC_CREAT);/*由关键字获得消息队列*/domsgrev(msgqid,&msg,1030,0,0);/火从队列msgid接受消息msg*/。printf("(server)receive\n");}while(msg.mtype!=1);/*消息类型为1时,释放队列*/msgctl(msgqid,IPC_RMID,0);}main()(if(fork())(SERVER();®wait(0);)oelseCLIENT();)2.共享存储区的创建,附接和断接:inc1ude<sys/types.h>inc1ude<sys/msg.h>include<sys/ipc.h>#dcfincSHMKEY75/*定义共享区关键词*/intshmid,i;int火addr;CLIENT()intshmid=shmget(SHMKEYJO24,0777|IPC.CREAT);/*获取共享区,长度1024,关键词SHMKEY*/»addr=shmat(shmid,O,0);/*共享区起始地址为addr*/。for(i=9;i>=0;i—)。o|0owhile(*addr!=-1);。printf("(client)sent\n");/大打.印(clienl)sent*/»。*addr=i;/*把i赋给addroexit(0);1SERVER(){do0{0mwhile(*addr==-1)?gprintf("(server)received\n%d",*addr);/*服务进程使用共享区*/if(*addr!=0)*addr=-1;}whi1e(*addr);。wait(0):shmctl(
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 企业间区块链安全智能合约的应用探索
- 公众健康教育与医疗卫生服务改进的联动机制研究
- 2025年电力工程项目发展计划
- 临时工劳务派遣劳动合同
- 宠物咬伤赔偿协议书
- 2024年西南证券股份有限公司招聘考试真题
- 2024年四川华丰科技股份有限公司招聘考试真题
- 个人房地产贷款抵押合同
- 2025年无缝管热连轧机项目发展计划
- 业务合作推广战略协议
- 2024年高考作文热点新闻素材积累与运用
- 《公共装置艺术》课件
- 个税赡养老人专项扣除协定书
- 消化道畸形课件
- 自来水过户转让协议
- 精神科诊疗常规及技术操作规范
- 2023年湖北高中学业水平合格性考试生物试卷真题(含答案详解)
- (医学课件)SOAP的规范书写及练习
- 【行业研究报告】2023年中国演出市场年度报告
- 向上管理的艺术(升级版):如何正确汇报工作
- 国开2023春计算机组网技术形考任务一参考答案
评论
0/150
提交评论