实验五进程间通信

实验五进程间通信

ID:22288356

大小:69.50 KB

页数:8页

时间:2018-10-28

实验五进程间通信_第1页
实验五进程间通信_第2页
实验五进程间通信_第3页
实验五进程间通信_第4页
实验五进程间通信_第5页
资源描述:

《实验五进程间通信》由会员上传分享,免费在线阅读,更多相关内容在学术论文-天天文库

1、实验5:进程间通信Ctrl+Alt+F6文本方式;Ctrl+Alt+F7图形方式一、消息的创建、发送和接收1.消息的创建、发送和接收使用系统调用msgget(),msgsnd(),msgrev(),及msgctl()编制-长度为1K的消息发送和接收的程序。(1)为了便于操作和观察结果,用-个程序作为“引子”,先后fork()两个子进程,SERVER和CLIENT,进行通信。(2)SERVER端建立-个Key为75的消息队列,等待其他进程发来的消息。当遇到类型为1的消息,则作为结束信号,取梢该队列,并退出SERVER。SERVER每接收到-个消息后显

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

3、消息结构{longmtype;charmtextl1030

4、;/*文本长度}msg;intmsgqidj;voidCLIENTO{inti;msgqid=msgget(MSGKE¥,0777);for(i=10;i>=l;i-){msg.mtype=i;printf(*'(client)sent*');msgsnd(msgqid,&msg,1024,0);/*发送消息msg入msgid消息队列*/>exit(0);}voidSERVER(){11邮9!(1=11邮86砂1501^¥,0777

5、1?€:_€1^八丁);产由关键字获得消息队列*/d

6、o{msgrcv(msg(

7、id,&msg,1030,0,0);/*从msgqid队列接收消息msg*/printf(,'(server)received,');}while(msg.mtype!=l);/*消息类型为1时,释放队列*/msgctl(msgqid,IPC_RMID,O);exit(O);}inain(){while((i=fork())==-l);if(!i)SERVERO;while((i=fork())==-l);if(!i)CLIENTO;wait(0);wait(O);)3.结果从理想的结果来说,应当是每当Clinet发

8、送-个消息后,Server接收该消息,Clinet再发送下-条。也就是说“(Clinet)sent"和“(server)received’1的字样应该在屏幕上交替出现。实际的结果大多是,先由Clinet发送了两条消息,然后Server接收-条消息。此后Clinet-Server交替发送和按收消息。最后Server一次接收两条消息。Client和Server分别发送和接收了10条消息,与预期设想-致。4.分析message的传送和控制并不保证完全同步,当-个程序不在激活状态的时候,它完全可能继续睡眠,造成了上曲的现象,在多次sendmessagedr

9、eceivemessage。这-点有助于理解消息传送的实现机理。二、共享存储区的创建,附接和断接1.系统调用使川系统调川shmget(),shmat(),shmdt(),shmctl(),^制-个与上述相同功能的程序。(1)为了便于操作和观察结果,用-个程序作为“引子”,先后forkO两个子进程,SERVER和CLIENT,进行通信。(2)SERVER端建立-个Key力75的共享区,并将第-个字节置为-1。作为数据空的标志。等待其他进程发来的消息。当该字节的值发生变化时,表示收到了信息,进行处理。然后再次把它的值设为-1。如果遇到的值为0,则视为结

10、朿信号,取消该队列,并退出SERVER。SERVER每接收到一次数裾后显示“(server)received”。(3)CLIENT端建立-个Key为75的共亨区,当共亨取得第一个字节为-1吋,Server端空闲,可发送请求。CLIENT随即填入9到0。期间等待Server端的再次空闲。进行完这些操作后,CLIENT退出。CLIENT每发送一次数据后显示“(client)sent”。(4)父进程在SERVER和CLIENT均退出后结束。2.程序#include#include#include

11、pc.h>#defineSHMKEY75/*定义共享区关键词intshmid,i;int*addr;voidCLIENTO

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

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

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