架构师之路013

进程与进程之间的协同

大体可以分为

互斥、同步、资源共享以及通讯等原语

进程内协同和进程间有啥不同?

早期 操作系统还只有进程这个唯一的执行体

如何在一个进程中启动另一个进程

  • 创建子进程
  • 让shell 配合执行某个动作

同步互斥相关的内容有

  • 锁mutex
  • 读写锁rwmutex
  • 信号量
  • 等待组
  • 条件变量

主流的操作系统 支持了锁和信号量

进程间的同步互斥并不牢靠

进程可能会异常挂掉

在获得了锁之后 异常挂掉 导致锁没有正常释放 另外一个等待该锁的进程可能会永远饥饿

两个进程再怎么隔离 有共同的中间人 就可以相互对话

中间人可以是谁? 共享资源

有哪些共享的存储型资源?

  • 文件系统
  • 剪切板

文件系统是天然的进程间通讯的中间人

文件的概念被抽象化 一切皆是文件

命名管道就是一种特殊的文件

和文件系统相关的进程间协同机制有

  • 文件
  • 文件锁
  • 管道(包括匿名管道和命名管道)
  • 共享内存

剪切板不是一个常规的进程间通讯方式

剪切板只有一个 有人共享数据上去 就会把别人的数据覆盖掉(类似单例)

其他的通讯机制。是基于网络的

进程在同一台机器上 同在一个局域网中

套接字作为网络通讯的抽象 本身就是最强大的通讯方式 没有之一

unix 还发明了一个专门用于本地通讯的套接字 unix域

通过一个name 来作为访问地址 而不是ip:port 来作为访问地址

ios 的操作系统

  • 软件不需要启动多份实例 一个软件只需启动一个进程实例
  • 大部分进程间的协同机制都是多余的 你只需要能够调用其他软件的能力 能够互斥 能够发送消息就够了
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值