这是继java 使用synchronized, wait(), notifyAll() 实现生产者-消费者模式的下一篇。
让我们先来看看什么是管程。管程的英文叫Monitor, 翻译过来时监视器的意思。为什么要使用管程呢? 之前使用信号量实现了同步互斥,但是信号量有个一个缺点,那就是P操作和V操作很容易搞错,如果一个地方进行了P操作,同步代码块执行完毕后忘记执行V操作,那么很容易引起死锁、饥饿等线程问题。这个问题类似C++里面对象的创建和销毁,如果没有及时delete可能会产生内存泄露,如果过早销毁则可能产生null pointer。 那管程其实就是为了实现信号量的功能,但是不用让编程人员来手动操作信号量。
来看看管程的模型:
从图中可以看到,各个线程首先等待在entry queue中,然后一次只能有一个线程被开发进入管程区去执行操作(Operations)。 当该线程不满足某个条件(比如条件X)时,该线程被挂在该条件变量的队列中进行等待(wait),同时会唤醒(signal)一个正在等待的线程,并且要释放当前拿到的锁。
有了上面的原理。我们