1、what's this?
1-1:将分散在各个进程中的临界区集中管理起来,并将共享资源用数据结构抽象地表示出来;
1-2:建立一个“秘书”程序来管理到来的访问;
1-3:秘书每次只让一个进程来访;
这个秘书就是管程。更正式的定义:一个管程定义了一个数据结构和能为并发进程所执行的在该数据结构上的一组操作,这组操作能同步进程和改变管程中的数据。
特点
共享性:管程被所有管理的进程所共享;安全性:管程的局部变量(数据结构)是私有的;互斥性:只有一个调用者可以进入管程(每次只允许一个)
2、why this?
背景:原本进程之间的同步操作由pv操作去控制,但pv操作大量分布于各个进程之中,难以管理,也容易发生死锁。
目的:引入管程的目的就是将各个进程之中的临界区集中起来管理,防止进程违反同步操作。如此也便于使用者去调用管程来书写程序。即封装了同步操作的细节,使得上层编程人员无需多了解,专心于自己的任务即可,程序也显得一目了然,正确性也比较容易验证。
3、how to use this?