IPC

IPC是进程间通信的简称。我们在一个系统上运行多个进程,每个进程都有各自的地址空间。Unix进程间的信息共享可以有多种方式。


(1)左边的两个进程共享留于文件系统的某个文件的某些信息。为了访问这些信息,每个进程都得穿越内核(read、write)。当有一个文件有待更新时,某种形式的同步是有必要的,这样既可以保护多个写入者,防止相互串扰,也可以保护一个或者多个读出者,防止写入者的干扰。

(2)中间的两个进程共享驻留于内核中的某些信息。管道是这种共享类型的一个例子,System V消息队列和System V信号量也是。

(3)右边的两个进程有一个双方都能访问的共享内存区。

IPC对象的持续性

IPC的持续性定义为该类型的一个对象一直存在多长时间。图1展示了三种类型的持续性。


随进程持续的IPC对象:管道和FIFO

随内核持续的IPC对象:System V消息队列、信号量和共享内存就是此类对象。

随文件系统持续的IPC对象:Posix消息队列、信号量和共享内存区如果是使用映射文件实现的,那么它们就是随文件系统持续的。


IPC名字空间:

当两个或多个无亲缘关系的进程使用某种类型的IPC对象来彼此交换信息时,该IPC对象必须有一个某种形式的名字或标识符,这样其中一个进程(往往是服务器)可以创建该IPC对象,其余进程则可以指定同一个IPC对象。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值