引入管程
PV操作困难,容易书写出错,引入管程,作为一种高级同步机制
组成
- 局限于管程的共享数据结构说明
- 对该数据结构进行操作的一组过程
- 对局部于管程的共享数据结构设置初始值的语句
- 管程有一个名字
基本特征
- 局限于管程的数据只能被局限于管程的过程所访问
- 一个进只有通过调用管程内的过程才能进入管程访问共享数据
- 每次仅允许一个进程在管程内执行某个内部过程
解决消费者问题
由于编译器保证了进程的互斥执行问题
需要在管程中定义好共享数据和访问入口,每次只会让一个进程/线程进入其中一个入口,这种互斥性由编译器负责实现
在管道设置条件变量以及等待/唤醒操作来解决同步问题
补充
synchronized与管程相当类似