多线程 Monitor.Pluse 与 Monitor.Wait 详解

/*
         * 当一个线程尝试着lock一个同步对象的时候,该线程就在就绪队列中排队。
         * 一旦没人拥有该同步对象,就绪队列中的线程就可以占有该同步对象。这也是我们平时最经常用的lock方法。
         * 为了其他的同步目的,占有同步对象的线程也可以暂时放弃同步对象,并把自己流放到等待队列中去。这就是Monitor.Wait。
         * 由于该线程放弃了同步对象,其他在就绪队列的排队者就可以进而拥有同步对象。
         * 比起就绪队列来说,在等待队列中排队的线程更像是二等公民:他们不能自动得到同步对象,甚至不能自动升舱到就绪队列。
         * 而Monitor.Pulse的作用就是开一次门,使得一个正在等待队列中的线程升舱到就绪队列;
         * 相应的Monitor.PulseAll则打开门放所有等待队列中的线程到就绪队列。
         *
         * 当线程调用 Wait 时,它释放对象的锁并进入对象的等待队列。对象的就绪队列中的下一个线程(如果有)获取锁并拥有对对象的独占使用。
         * 所有调用 Wait 的线程都将留在等待队列中,直到它们接收到由锁的所有者发送的 Pulse 或 PulseAll 的信号为止。
         * 如果发送了 Pulse,则只影响位于等待队列最前面的线程。 如果发送了 PulseAll,则将影响正等待该对象的所有线程。
         * 接收到信号后,一个或多个线程将离开等待队列而进入就绪队列。 就绪队列中的线程被允许重新获取锁。
         * 当调用线程重新获取对象上的锁后,此方法将返回。 请注意,如果锁的持有者不调用 Pulse 或 PulseAll,则此方法将无限期地阻止
        */

posted @ 2014-03-31 13:25  xust  阅读(390)  评论(0)    收藏  举报