- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
进程间通信与应用程序间通信及其实现技术
摘 要 本文讨论了进程间通信与应用程序间通信的含义及相应的实现技术,并对这些技术的原理、特性等进行了深入的分
析和比较。
关键词 信号 管道 消息队列 共享存储段 信号灯 远程过程调用 Socket 套接字 MQSeries
1 引言
进程间通信的主要目的是实现同一计算机系统内部的相互协作的进程之间的数据共享与信息交换,由于这些进程处于同一
软件和硬件环境下,利用操作系统提供的的编程接口,用户可以方便地在程序中实现这种通信;应用程序间通信的主要目的是
实现不同计算机系统中的相互协作的应用程序之间的数据共享与信息交换,由于应用程序分别运行在不同计算机系统中,它们
之间要通过网络之间的协议才能实现数据共享与信息交换。进程间通信和应用程序间通信及相应的实现技术有许多相同之处,
也各有自己的特色。即使是同一类型的通信也有多种的实现方法,以适应不同情况的需要。
为了充分认识和掌握这两种通信及相应的实现技术,本文将就以下几个方面对这两种通信进行深入的讨论:问题的由来、
解决问题的策略和方法、每种方法的工作原理和实现、每种实现方法的特点和适用的范围等。
2 进程间的通信及其实现技术
用户提交给计算机的任务最终都是通过一个个的进程来完成的。在一组并发进程中的任何两个进程之间,如果都不存在公
共变量,则称该组进程为不相交的。在不相交的进程组中,每个进程都独立于其它进程,它的运行环境与顺序程序一样,而且
它的运行环境也不为别的进程所改变。运行的结果是确定的,不会发生与时间相关的错误。
但是,在实际中,并发进程的各个进程之间并不是完全互相独立的,它们之间往往存在着相互制约的关系。进程之间的相
互制约关系表现为两种方式:
(1 ) 间接相互制约:共享 CPU
(2 ) 直接相互制约:竞争和协作
竞争 —— 进程对共享资源的竞争。为保证进程互斥地访问共享资源,各进程必须互斥地进入各自的临界段。
协作 —— 进程之间交换数据。为完成一个共同任务而同时运行的一组进程称为同组进程,它们之间必须交换数据,以达到
协作完成任务的目的,交换数据可以通知对方可以做某事或者委托对方做某事。
共享 CPU 问题由操作系统的进程调度来实现, 进程间的竞争和协作由进程间的通信来完成。 进程间的通信一般由操作系统
提供编程接口, 由程序员在程序中实现。 UNIX 在这个方面可以说最具特色, 它提供了一整套进程间的数据共享与信息交换的处
理方法 —— 进程通信机制( IPC )。因此,我们就以 UNIX 为例来分析进程间通信的各种实现技术。
在 UNIX 中,文件( File )、信号( Signal )、无名管道( Unnamed Pipes )、有名管道( FIFOs )是传统 IPC 功能;
新的 IPC 功能包括消息队列( Message queues )、共享存储段( Shared memory segment )和信号灯( Semapores )。
(1 ) 信号
信号机制是 UNIX 为进程中断处理而设置的。它只是一组预定义的值,因此不能用于信息交换,仅用于进程中断控制。例
如在发生浮点错、非法内存访问、执行无效指令、某些按键(如 ctrl-c 、del 等)等都会产生一个信号,操作系统就会调用有关
的系统调用或用户定义的处理过程来处理。
信号处理的系统调用是 signal ,调用形式是:
signal(signalno,action)
其中, signalno 是规定信号编号的值, action 指明当特定的信号发生时所执行的动作。
(2 ) 无名管道和有名管道
无名管道实际上是内存中的一个临时存储区,它由系统安全控制,并且独立于创建它的进程的内存区。管道对数据采用先
进先出方式管理,并严格按顺序操作,例如不能对管道进行搜索,管道中的信息只能读一次。
无名管道只能用于两个相互协作的进程之间的通信,并且访问无名管道的进程必须有共同的祖先。
系统提供了许多标准管道库函数,如:
pipe() ——打开一个可以读写的管道;
close() ——关闭相应的管道;
read() ——从管道中读取字符;
write() ——向管道中写入字符;
有名管道的操作和无名管道类似,不同的地方在于使用有名管道的进程不需要具有共同的祖先,其它进程,只要知道该管
道的名字,就可以访问它。管道非常适合进程之间快速交换信息。
(3 ) 消息队列( MQ
您可能关注的文档
最近下载
- 钢结构吊装专项施工方案(技术方案).doc
- 中国成人念珠菌病诊断与治疗专家共识解读PPT课件.pptx VIP
- 05S804:矩形钢筋混凝土蓄水池.pdf VIP
- 01-泌尿系统疾病总论.ppt VIP
- 物理治疗学神经生理疗法Bobath技术.docx VIP
- Unit 3 My favourite food Lesson 2 Happy birthday, Amber! 单元教学设计 粤教沪外教版英语三年级下册.docx
- Andrews分析法诊断正畸.pptx
- (新课程中小学科学教学设计与案例分析提纲及答案2.doc VIP
- 2025年湖北省遴选面试真题及答案大全解析.docx VIP
- DB11T 1832.15-2022 建筑工程施工工艺规程 第15部分:通风与空调安装工程 conv.docx VIP
原创力文档


文档评论(0)