join,wait线程理解

参考书目《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线程,由于相互间的切换所以会抛出中断异常,这里只考虑临界区的同步问题,没有原子性操作。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值