线程间通信
其实就是多个线程在操作同一个资源,但是操作的动作不同。
wait(),notify(),notifyall();
都使用在同步中,因为要对持有监视器(锁)的线程操作。
所有要使用在同步中,因为只有同步才具有锁。
为什么操作线程的方法要定义在object类中?
因为这些方法在操作同步中线程时,都必须要标识它们所操作线程持有的锁,
只有同一个锁上的被等待线程,可以被同一个锁上notify唤醒。
不可以对不同锁中的线程进行唤醒。也就是说,等待和唤醒必须是同一个锁。
其实就是多个线程在操作同一个资源,但是操作的动作不同。
wait(),notify(),notifyall();
都使用在同步中,因为要对持有监视器(锁)的线程操作。
所有要使用在同步中,因为只有同步才具有锁。
为什么操作线程的方法要定义在object类中?
因为这些方法在操作同步中线程时,都必须要标识它们所操作线程持有的锁,
只有同一个锁上的被等待线程,可以被同一个锁上notify唤醒。
不可以对不同锁中的线程进行唤醒。也就是说,等待和唤醒必须是同一个锁。
而锁可以是任意对象,所有可以被任意对象调用的方法定义在object类中。
对于多个生产者和消费者
为什么要定义while判断标记。
原因:让被唤醒的线程再一次判断标记。
为什么定义notifyAll
因为需要唤醒对方线程。
因为只用notify,容易出现只唤醒本方线程的情况。导致程序中的所有线程都等待。
JDK1.5中提供了多线程升级解决方案。
将同步Synchronized替换成现实Lock操作。
将object中的wait,notify,notifyAll,替换了condition对象。
该对象可以Lock锁进行获取。可以实现本方只唤醒对方操作。
停止线程
stop方法已经过时。停止线程,只有一种,r