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

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

ID:58539516

大小:106.50 KB

页数:4页

时间:2020-05-19

操作系统实验3--进程间通信.doc_第1页
操作系统实验3--进程间通信.doc_第2页
操作系统实验3--进程间通信.doc_第3页
操作系统实验3--进程间通信.doc_第4页
资源描述:

《操作系统实验3--进程间通信.doc》由会员上传分享,免费在线阅读,更多相关内容在工程资料-天天文库

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每接

3、收到一个消息后显示一句“(server)received”。(3)CLIENT端使用Key为75的消息队列,先后发送类型从10到1的消息,然后退出。最后的一个消息,既是SERVER端需要的结束信号。CLIENT每发送一条消息后显示一句“(client)sent”。(4)父进程在SERVER和CLIENT均退出后结束。〈程序〉#include#include#include#include#defineMSGKEY75/*定义关键词MEGKEY*/s

4、tructmsgform/*消息结构*/{longmtype;charmtexe[1030];/*文本长度*/}msg;intmsgqid,i;voidCLIENT(){inti;msgqid=msgget(MSGKEY,0777);for(i=10;i>=1;i--){msg.mtype=i;printf("(client)sent");msgsnd(msgqid,&msg,1024,0);/*发送消息msg入msgid消息队列*/}exit(0);}voidSERVER(){msgqid=msgget(MSGKEY,0777

5、

6、IPC_CREAT);/*由关键字获得消息队列*/do{msgrcv(msgqid,&msg,1030,0,0);/*从队列msgid接受消息msg*/printf("(server)receive");}while(msg.mtype!=1);/*消息类型为1时,释放队列*/msgctl(msgqid,IPC_RMID,0);exit(0);}main(){if(fork())SERVER();elseCLIENT();wait(0);wait(0);}程序执行结果2、共享存储区的创建,附接和断接(1)为了便于操作和观察结果,用

7、一个程序为“引子”,先后fork()两个子进程,SERVER和CLIENT,进行通信。(2)SERVER端建立一个KEY为75的共享区,并将第一个字节置为-1.作为数据空的标志.等待其他进程发来的消息.当该字节的值发生变化时,表示收到了该消息,进行处理.然后再次把它的值设为-1.如果遇到的值为0,则视为结束信号,取消该队列,并退出SERVER.SERVER每接收到一次数据后显示”(server)received”.(3)CLIENT端建立一个为75的共享区,当共享取得第一个字节为-1时,Server端空闲,可发送请求.CLIENT随即

8、填入9到0.期间等待Server端再次空闲.进行完这些操作后,CLIENT退出.CLIENT每发送一次数据后显示”(client)sent”.(4)父进程在SERVER和CLIENT均退出后结束.<程序>#include#include#include#defineSHMKEY75/*定义共享区关键词*/intshmid,i;int*addr;CLIENT(){inti;shmid=shmget(SHMKEY,1024,0777);addr=shmat(shmid,

9、0,0);/*共享区起始地址为addr*/for(i=9;i>=0;i--){while(*addr!=-1);printf("(client)sent");/*打印(client)sent*/*addr=i;/*把

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。