进程,线程与信息共享

      按照传统的 Unix 编程模型,我们在一个系统上运行多个进程,每个进程都有各自的地址空间。Unix 进程间的信息共享可以有多种方式。下图说明了共享信息的三种方式:


      

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

      (2)中间的两个进程共享驻留于内核中的某些信息。管道是这种共享类型的一个例子,System V 消息队列和 System V 信号量也是。现在访问共享信息的每次操作涉及对内核的一次系统调用

      (3)右边的两个进程有一个双方都能访问的共享内存区。每个进程一旦设置好该共享内存区,就能根本不涉及内核而访问其中的数据。共享该内存区的进程需要某种形式的同步

      注:注意没有任何东西限制任何 IPC 技术只能使用两个进程。这里讲述的技术适用于任意数目的进程。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值