Java线程同步简介
一、要领先容
1、void wait()
使得线程进入期待状态,直到它被其他线程通过notify()可能notifyAll叫醒。该要领只能在同步要领(void synchronized methodName( args… ){ … })可能 “同步块内部“ (synchronized(object){ … })被挪用。假如当前线程不是锁的持有者,该要了解抛出一个IllegalMonitorStateException异常。
即假如锁住的是object,那么你只能挪用object的wait()要领。
2、void notify()
随机选择一个在该工具上挪用wait要领的线程,清除其阻塞状态。该要领只能在同步要领(void synchronized methodName( args… ){ … })可能 “同步块内部“ (synchronized(object){ … })被挪用。假如当前线程不是锁的持有者,该要了解抛出一个IllegalMonitorStateException异常。
3、void notifyAll()
清除所有那些在该工具上挪用wait要领的线程的阻塞状态。该要领只能在同步要领(void synchronized methodName( args… ){ … })可能 “同步块内部“ (synchronized(object){ … })被挪用。假如当前线程不是锁的持有者,该要了解抛出一个IllegalMonitorStateException异常。
二、典型讲授( 留意测试类A只能声明为外部类,下面代码在 class A 和 main要领 之间 省略了MainClass { … } )
1、“同步块”测试
(1)加synchronized(){}
class A{} public static void main(String[] args) { A object = new A(); System.out.println("Main Thread Id = " + Thread.currentThread().getId()); synchronized (object) { try { System.out.println("This Thread Id = " + Thread.currentThread().getId()); object.wait(); } catch (InterruptedException e) { </span>e.printStackTrace(); } } }
输出
(2)不加synchronized(){}
class A{} public static void main(String[] args) { A object = new A(); System.out.println("Main Thread Id = " + Thread.currentThread().getId()); //synchronized (object) { try { </span>System.out.println("This Thread Id = " + Thread.currentThread().getId()); </span>object.wait(); } catch (InterruptedException e) { </span>e.printStackTrace(); } /
URL:http://www.bianceng.cn/Programming/Java/201608/50367.htm