




已阅读5页,还剩2页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
软件学院计算机课程实 验 报 告 册课程名称 计算机操作系统 实验学期 2011 年至 2012 年 第 2 学期学生所在院(系) 软件学院 年级 11软件 专业班级 软工(1) 班学生姓名 朱水云 学号 1115114034 指导教师 陈自刚 实验最终成绩 软件学院实验室制2012 年 4 月实验报告( 二 )分数:实验教师:实验名称:进程间通信 实验时间:2012年4月18号 实验性质 一、实验目的及要求:Linux系统的进程通信机构 (IPC) 允许在任意进程间大批量地交换数据。本实验的目的是了解和熟悉Linux支持的消息通讯机制及信息量机制。二、实验内容与分析设计:1.消息的创建,发送和接收。 使用系统调用msgget (), msgsnd (), msgrev (), 及msgctl () 编制一长度为1k的消息的发送和接收程序。 观察上面的程序,说明控制消息队列系统调用msgctl () 在此起什么作用?分析设计:(1) 为了便于操作和观察结果,用一个 程序为“引子”,先后fork( )两个子进程,SERVER和CLIENT,进行通信。(2) SERVER端建立一个Key为75的消息队列,等待其他进程发来的消息。当遇到类型为1的消息,则作为结束信号,取消该队列,并退出SERVER 。SERVER每接收到一个消息后显示一句“(server)received”。(3) CLIENT端使用Key为75的消息队列,先后发送类型从10到1的消息,然后退出。最后的一个消息,既是 SERVER端需要的结束信号。CLIENT每发送一条消息后显示一句“(client)sent”。(4) 父进程在 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接收一条消息。此后ClientServer交替发送和接收消息.最后一次接收两条消息. Client 和Server 分别发送和接收了10条消息,与预期设想一致message的传送和控制并不保证完全同步,当一个程序不再激活状态的时候,它完全可能继续睡眠,造成上面现象,在多次send message 后才 receive message.这一点有助于理解消息转送的实现机理.2.共享存储区的创建、附接和段接运行的结果和预想的完全一样。但在运行的过程中,发现每当client发送一次数据后,server要等大约0.1秒才有响应。同样,之后client又需要等待大约0.1秒才发送下一个数据。出现上述的应答延迟的现象是程序设计的问题。当client端发送了数据后,并没有任何措施通知server端数据已经发出,需要由client的查询才能感知。此时,client端并没有放弃系统的控制权,仍然占用CPU的时间片。只有当系统进行调度时,切换到了server进程,再进行应答。这个问题,也同样存在于server端到client的应答过程之中。六、主要算法和程序清单1.消息的创建,发送和接收程序#include #include #include #include #define MSGKEY 75 /*定义关键词MEGKEY*/struct msgform /*消息结构*/long mtype;char mtexe100; /*文本长度*/msg;int msgqid,i;void CLIENT( )int i;msgqid=msgget(MSGKEY,0777|IPC_CREAT);for(i=10;i=1;i-) msg.mtype=i; printf(client)sentn); msgsnd(msgqid,&msg,1030,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.mtype!=1); /*消息类型为1时,释放队列*/ msgctl(msgqid, IPC_RMID,0);main() if(fork() SERVER(); wait(0);else CLIENT( );2.共享存储区的创建、附接和段接#include#include#include#define SHMKEY 75 /*定义共享区关键词*/int shmid,i;int *addr; CLIENT()int i;shmid=shmget(SHMKEY,1024, 0777|IPC_CREAT); /*获取共享区,长度1024,关键词SHMKEY*/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() dowhile(*addr = =-1);printf(server)receivedn%d,*addr); /*服务进程使用共享区*/if(*addr!=0)*addr=-1; while(*addr); wait(0);shmc
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 日照市莒县中小学美术教师招聘考试试题及答案
- 2025年机务检修考试试题及答案
- 2025年铁路机务试题及答案
- 高企调账合同模板(3篇)
- qc知识考试试题及答案
- 现代农业企业代理记账服务合同
- 文化产业项目投资担保合同模板
- 剑桥数学专业测试题及答案
- 园长专业考试试题及答案
- 危重昏迷患者的心理护理
- GB/T 21220-2024软磁金属材料
- 2.1 地表形态变化的内外力作用-内力作用 中图版(2019)地理选择性必修一高二上学期
- 数字化印花工艺智能化
- 成人鼻肠管的留置与维护
- 专题02 概率与统计解答题综合(解析版)
- MOOC 模拟电子电路实验-东南大学 中国大学慕课答案
- 多格列艾汀使用指南2024课件
- MOOC 创业基础-暨南大学 中国大学慕课答案
- (2024年)面神经炎课件完整版
- GB/T 41666.4-2024地下无压排水管网非开挖修复用塑料管道系统第4部分:原位固化内衬法
- 云端药历健保署电子病历-慈济大学医学资讯学系
评论
0/150
提交评论