进程与进程之间的协同
大体可以分为
互斥、同步、资源共享以及通讯等原语
进程内协同和进程间有啥不同?
早期 操作系统还只有进程这个唯一的执行体
如何在一个进程中启动另一个进程
- 创建子进程
- 让shell 配合执行某个动作
同步互斥相关的内容有
- 锁mutex
- 读写锁rwmutex
- 信号量
- 等待组
- 条件变量
主流的操作系统 支持了锁和信号量
进程间的同步互斥并不牢靠
进程可能会异常挂掉
在获得了锁之后 异常挂掉 导致锁没有正常释放 另外一个等待该锁的进程可能会永远饥饿
两个进程再怎么隔离 有共同的中间人 就可以相互对话
中间人可以是谁? 共享资源
有哪些共享的存储型资源?
- 文件系统
- 剪切板
文件系统是天然的进程间通讯的中间人
文件的概念被抽象化 一切皆是文件
命名管道就是一种特殊的文件
和文件系统相关的进程间协同机制有
- 文件
- 文件锁
- 管道(包括匿名管道和命名管道)
- 共享内存
剪切板不是一个常规的进程间通讯方式
剪切板只有一个 有人共享数据上去 就会把别人的数据覆盖掉(类似单例)
其他的通讯机制。是基于网络的
进程在同一台机器上 同在一个局域网中
套接字作为网络通讯的抽象 本身就是最强大的通讯方式 没有之一
unix 还发明了一个专门用于本地通讯的套接字 unix域
通过一个name 来作为访问地址 而不是ip:port 来作为访问地址
ios 的操作系统
- 软件不需要启动多份实例 一个软件只需启动一个进程实例
- 大部分进程间的协同机制都是多余的 你只需要能够调用其他软件的能力 能够互斥 能够发送消息就够了