参考书目《java核心技术卷1》
wait(),notify(),notifyAll()这三种方法属于Object对象,且只能放在一个同步方法当中,而且对于当前线程不是对象锁的持有者,这些方法会抛出IllegalMonitorStateException异常,而且notify()随机选择一个在该对象上调用wait()方法的线程,解除其阻塞状态,如果不满足条件,则会继续阻塞,所以容易产生死锁现象。对于wait()方法是会释放对象锁的,所以在临界域里面可能会存在多个阻塞的线程,但是最终都唤醒之后,只会有一个进入临界区域。而对于join()方法,只是等待对应线程结束后,但是不释放对象锁。
class Th1 implements Runnable{
public void run() {
Thread b=new Thread(new Th2());
b.start();
try {
b.join();
} catch (InterruptedException e) {
e.printStackTrace();
}
for(int i=0;i<5;i++)
System.out.println("A"+i);
}
}
class Th2 implements Runnable{
public void run() {
for(int i=0;i<5;i++)
System.out.println("B"+i);
}
}
public class Rewrite {
public static void main(String[] args) throws InterruptedException{
Thread a=new Thread(new Th1());
a.start();
a.join();
System.out.println("Main ended.");
}
}
测试结果:B0 B1 B2 B3 B4 A0 A1 A2 A3 A4 Main ended.可以看出在main线程当中线程A先执行,在线程B先执行,如果将Th1中的try块注释掉,则A和B线程会交替进行,但是对于主线程仍然在A,B线程之后。对于A和B线程,由于相互间的切换所以会抛出中断异常,这里只考虑临界区的同步问题,没有原子性操作。