什么是进程间通信

     进程间通信(IPC)是在多任务操作系统或联网的计算机之间运行的程序和进程所用的通信技术。有两种类型的进程间通信(IPC)。
  本地过程调用(LPC)LPC用在多任务操作系统中,使得同时运行的任务能互相会话。这些任务共享内存空间使任务同步和互相发送信息。
  远程过程调用(RPC)RPC类似于LPC,只是在网上工作。RPC开始是出现在Sun微系统公司和HP公司的运行UNIX操作系统的计算机中。
  通过IPC和RPC,程序能利用其它程序或计算机处理的进程。客户机/服务器模式计算把远程过 程调用与其它技术如消息传递一道,作为系统间通信的一种机制。客户机执行自己的任务,但靠服务器提供后端文件服务。RPC为客户机提供向后端服务器申请服 务的通信机制,如图R-4所示。如果你把客户机/服务器应用程序想作是一个分离的程序,服务器能运行数据访问部分,因为它离数据最近,客户机能运行数据表 示和与用户交互的前端部分。这样,远程过程调用可看作是把分割的程序通过网络重组的部件。LPC有时也称耦合(Coupling)机制。
  用这种方式分割程序,当用户要访问数据时就无需每次拷贝整个数据库或它的大部分程序到用户系统。其实,服务器只处理请求,甚至只执行一些数据计算,把得出的结果再发送给用户。因为当数据存放在一个地方时,数据库同步很容易实现,所以多个用户可同时访问相同的数据。

转载于:https://www.cnblogs.com/yours369000/archive/2009/08/21/1551577.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
进程通信是指不同进程进行相互传播或交换信息的过程。在操作系统中,进程通信是非常重要的,因为不同进程需要共享资源或者协同完成任务。常见的进程通信方式有以下几种: 1. 管道(Pipe):管道是一种半双工的通信方式,数据只能单向流动,而且只能在具有亲缘关系的进程使用。 2. 命名管道(FIFO):命名管道也是一种半双工的通信方式,但是可以在不具有亲缘关系的进程使用。 3. 信号量(Semaphore):信号量是一种计数器,用于控制多个进程对共享资源的访问。 4. 消息队列(Message Queue):消息队列是一种消息的链表,存放在内核中并由消息队列标识符标识。 5. 共享内存(Shared Memory):共享内存是最快的一种进程通信方式,它允许多个进程共享同一块物理内存。 6. 套接字(Socket):套接字是一种网络通信协议,可以在不同主机之进行进程通信。 以下是一个使用共享内存实现进程通信的Python代码示例: ```python import multiprocessing def producer(ns, event): ns.value = 'Hello, world!' event.set() def consumer(ns, event): try: event.wait() print(ns.value) except Exception as e: print(e) if __name__ == '__main__': mgr = multiprocessing.Manager() ns = mgr.Namespace() event = multiprocessing.Event() p = multiprocessing.Process(target=producer, args=(ns, event)) c = multiprocessing.Process(target=consumer, args=(ns, event)) p.start() c.start() p.join() c.join() ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值