第5次小课进程间通信(中).pptVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
实用操作系统 华软软件学院软件工程系 P* 第五次小课 进程间通信 (中) 华软软件工程系 (中) 主要章节 进程间通信实验课主要内容 本周大课内容回顾 通过实验理解消息缓冲通信 通过实验理解共享内存通信 了解消息缓冲通信与内存共享通信之间的差异 主要内容 注意 本次实验需要提交实验报告,请按照所提供实验报告模板把内容填充完整后上传到FTP对应文件夹. 上传地址:FTP://40 帐号密码:upload_1316 第一部分 本周大课 内容回顾 进程间通信(中) 消息缓冲通信 共享内存通信 主要内容 Linux的IPC机制 Linux的IPC的含义是?IPC对象有哪几种? IPC—Inter Process Communication,进程间通信。 Linux的IPC机制包含如下IPC对象:消息队列、共享内存、信号量集(未讲) IPC对象 每个IPC对象拥有唯一的IPC标识(ipc_ids和ipc_id) 每个IPC对象都有一个公共的ipc_perm结构,其中拥有一个唯一的key 理解IPC标识符与key的差异 理解ipc_perm结构中mode的定义 ipc_perm在Linux中为kern_ipc_perm结构 Linux的IPC机制(5) 消息队列是临界资源吗?对同一个消息队列进行访问的多个发送和接收进程存在何种制约关系? 消息队列通信的缺点是? 由shmget获得的共享内存区域是属于何种类型?(选项有物理内存页面 or磁盘文件) 共享内存通信相对消息队列通信的优点是?仍存在的问题? Linux消息缓冲通信 创建或获取消息队列标识: int msgget(key_t key,int msgflag) 发送消息到指定队列: int msgsnd(int msgid,struct msgbuf* msgp,int size,int flag) 从指定队列中接收消息: Int msgrcv(int msgid,struct msgbuf* msgp,int size, int type, int flag) Type=0接收队列的第一个消息;0接收类型type的第一个消息;0接收小于或等于| type |的最低类型的第一个消息。 消息队列状态查询、修改或撤销队列: int msgctl(int msgid, int cmd, struct msgid_ds *buf) Linux共享内存通信(2) shmget(key,size,flag):创建或获取共享内存id shmat(int shmid,char *shmaddr,int msgflg,ulong *raddr) shmat(int shmid,int *shmaddr,int msgflg,ulong *raddr) :附接到共享内存 shmdt(viraddr):切断与共享内存的连接 shmctl(int shmid,int cmd,struct shmid_ds *buf):共享内存的状态查询、修改或撤销 第二部分 进程间通信 实验 进程间通信(中) 消息缓冲通信 共享内存通信 主要内容 进程间通信实验 消息缓冲通信实验 利用消息缓冲通信方式,实现消息的发送与接收。 发送进程sndfile.c将要发送的消息从键盘输入,每输入一行就作为一条消息发送,用end作为结束消息 接收进程rcvfile.c从消息队列逐个接收信息并显示,用 end作为结束消息 设消息队列的key值为1234 目的:了解缓冲消息通信的编程实现 理解要点: my_msg结构就是msgbuf结构,需自定义 msgget()、msgsnd()、msgrcv()函数的使用 采用各种方式或顺序运行此二进程,观察结果 解题思路 sndfile.c 定义消息缓冲区数据结构(my_msg); 通过msgget()创建消息队列; while(1){ 提示用户输入消息内容; 标准输入stdin送buffer; buffer中的内容复制到消息缓冲; 通过msgsnd()发送消息; 消息为”end”结束; } rcvfile.c 定义消息缓冲区数据结构(my_msg); 通过msgget()获取消息队列; while(1){ 通过msgrcv()接收消息内容; 显示消息; 消息为”end”结束; } 2个程序:sndfile.c和rcvfile.c 改造: 1、尝试使用发送与接收中的key值不一样或者设为0,看看是怎样的结果。 Sndfile.c Rcvfile.c 进程间通信实验(2) 共享内存通信实验(sndshm.c和rcvshm.c) 利用共享内存的方式,实现前一实验的基本目标 目的:了解共享内存通信 理解要点: shmget()、shmat()、shmdt()、shmctl()的使用

文档评论(0)

zyg_2930102 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档