- 1、本文档共8页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
进程间通信验报告
软件学院计算机课程
实 验 报 告 册
课程名称 计算机操作系统
实验学期 2011 年至 2012 年 第 2 学期
学生所在院(系) 软件学院
年级 11软件 专业班级 软工(1) 班
学生姓名 朱水云 学号 1115114034
指导教师 陈自刚
实验最终成绩
软件学院实验室制
2012 年 4 月
实验报告( 二 )
分数:实验教师:实验名称:进程间通信
分数:
实验教师:
实验时间:2012年4月18号
实验性质
一、实验目的及要求:
Linux系统的进程通信机构 (IPC) 允许在任意进程间大批量地交换数据。本实验的目的是了解和熟悉Linux支持的消息通讯机制及信息量机制。
二、实验内容与分析设计:
1.消息的创建,发送和接收。
①使用系统调用msgget (), msgsnd (), msgrev (), 及msgctl () 编制一长度为1k的消息的发送和接收程序。
②观察上面的程序,说明控制消息队列系统调用msgctl () 在此起什么作用?
分析设计:
为了便于操作和观察结果,用一个 程序为“引子”,先后fork( )两个子进程,SERVER和CLIENT,进行通信。
SERVER端建立一个Key为75的消息队列,等待其他进程发来的消息。当遇到类型为1的消息,则作为结束信号,取消该队列,并退出SERVER 。SERVER每接收到一个消息后显示一句“(server)received”。
CLIENT端使用Key为75的消息队列,先后发送类型从10到1的消息,然后退出。最后的一个消息,既是 SERVER端需要的结束信号。CLIENT每发送一条消息后显示一句“(client)sent”。
父进程在 SERVER和 CLIENT均退出后结束。
2.共享存储区的创建、附接和段接。
使用系统调用shmget(),shmat(),sgmdt(),shmctl(),编制一个与上述功能相同的程序。
比较上述(1),(2)两种消息通信机制中数据传输的时间。
(1)为了便于操作 和观察结果,用一个 程序为“引子”,先后fork( )两个子进程,SERVER 和 CLIENT,进行通信。
(2)SERVER端建立一个KEY为75的共享区,并将第一个字节置为-1.作为数据空的标志.等待其他进程发来的消息.当该字节的值发生变化时,表示收到了该消息,进行处理.然后再次把它 的值设为-1.如果遇到的值为0,则视为结束信号,取消该队列,并退出SERVER.SERVER每接 收到一次数据后显示”(server)received”.
(3)CLIENT端建立一个为75的共享区,当共享取得第一个字节为-1时, Server端空闲,可发送 请求. CLIENT 随即填入9到0.期间等待Server端再次空闲.进行完这些操作后, CLIENT 退出. CLIENT每发送一次数据后显示”(client)sent”.
(4)父进程在SERVER和CLIENT均退出后结束.
三、实验步骤与调试过程:
1,启动计算机并运行linux系统
2,打开中断进行程序书写
3,根据Linux系统的gcc自带编译器进行运行编译
4,分析运行出现的问题
5,观察运行结果,并思考
6,退出中断并写出实验报告
调试过程:根据编译提示的错误进行修改
四、实验结果:
1消息的发送和接受运行结果:
2.共享存储区的创建、附接和段接运行结果:
五、疑难与小结:
1.消息的创建,发送和接收小结:从理想的结果来说,应当是每当Client发送一个消息后,server接收该消息,Client再发送下一条。也就是说“(Client)sent”和“(server)received”的字样应该在屏幕上交替出现。实际的结果大多是,先由 Client 发送两条消息,然后Server接收一条消息。此后Client
Server交替发送和接收消息.最后一次接收两条消息. Client 和Server 分别发送和接收了10条消息,与预期设想一致message的传送和控制并不保证完全同步,当一个程序不再激活状态的时候,它完全可能继续睡眠,造成上面现象,在多次send message 后才 receive message.这一点有助于理解消息转送的实现机理.
2.共享存储区的创建、附接和段接运行的结果和预想的完全一样。但在运行的过程中,发现每当client发送一次数据后,server要等大约0.
您可能关注的文档
- 超市库存管系统(大作业) 2.doc
- 跟双宾语与补结构的动词.doc
- 职称计算机证试题:新建一个25像素25像素,分辨率为300ppi,背景为白色的“RGB”模式文件.doc
- 跨越式跳高元教学计划.doc
- 跳短绳说课例反思教案.doc
- 车站作业计课程设计任务书2012.doc
- 赵同学:清大学五道口金融硕士考研经验须知.doc
- 辩论赛开幕暨表演赛策划书-最终版.doc
- 软件工程案开发与实践4-1.ppt
- 辅导课教案一).doc
- 第12课 大一统王朝的巩固 课件(20张ppt).pptx
- 第17课 君主立宪制的英国 课件.pptx
- 第6课 戊戌变法 课件(22张ppt).pptx
- 第三章 物态变化 第2节_熔化和凝固_课件 (共46张ppt) 人教版(2024) 八年级上册.pptx
- 第三章 物态变化 第5节_跨学科实践:探索厨房中的物态变化问题_课件 (共28张ppt) 人教版(2024) 八年级上册.pptx
- 2025年山东省中考英语一轮复习外研版九年级上册.教材核心考点精讲精练(61页,含答案).docx
- 2025年山东省中考英语一轮复习(鲁教版)教材核心讲练六年级上册(24页,含答案).docx
- 第12课近代战争与西方文化的扩张 课件(共48张ppt)1.pptx
- 第11课 西汉建立和“文景之治” 课件(共17张ppt)1.pptx
- 唱歌 跳绳课件(共15张ppt内嵌音频)人音版(简谱)(2024)音乐一年级上册第三单元 快乐的一天1.pptx
文档评论(0)