线程中的join方法一定会释放锁,但是它释放的却是这个锁

如果在主线程中调用该join方法时就会让主线程休眠,让调用join()方法的线程先执行完毕后再开始执行主线程。join方法会释放锁,那么它会释放哪个锁呢?
线程中的join方法一定会释放锁,但是它释放的却是这个锁_第1张图片

如上所示,我们可以看到我们开启了一个thread1线程,然后这个线程中有synchronized代码块,它的锁是o1对象,然后在main线程中也有一个synchronized,它的锁也是o1,也就是说这两个线程中同步使用的是同一个锁,这个程序的执行结果为:线程中的join方法一定会释放锁,但是它释放的却是这个锁_第2张图片

我们可以看到开启thread1线程之后,并没有给这个线程CPU呢,而是继续往下执行,所以主方法就拿到了这个锁o1,执行到mian–19的时候程序就停止住了,这是因为当主线程中i=20的时候,此时调用了thread1.join方法,然后当前主线线程就需要等待thread1线程执行完成,但是thread1执行需要o1对象锁,但是此时主线程拿着呢,所以thread1拿不到,那么此时就出问题了。这个侧面说明了一个问题,thread1.join并不会让主线程main释放o1这个锁,那么到底它释放了什么锁呢?其实它让main线程释放了thread1这个对象这个锁,下面通过一个例子来看一下:线程中的join方法一定会释放锁,但是它释放的却是这个锁_第3张图片

我们可以看到这个程序,其中主线程的代码块中使用的是thread1对象这个锁,而线程thread1也是使用thread1这个锁,也就是它本身,我们执行这个程序可以看到,并没有出现上面卡顿的情况?
线程中的join方法一定会释放锁,但是它释放的却是这个锁_第4张图片

这就证明了thread1.join的时候,父线程释放了thread1,也就是线程对象这个锁,所以线程thread1就可以获取到thread1这个锁了,所以就可以保证它的执行,它执行完毕之后就会继续执行父线程,也就是main线程,就不会出问题了。

你可能感兴趣的:(java,多线程,thread,并发编程)