Java线程挂起有哪些具体实现方法详细解析?
- 内容介绍
- 文章标签
- 相关推荐
本文共计769个文字,预计阅读时间需要4分钟。
前言:在Java中使用线程的时候,可能会遇到线程挂起的情况。Java提供了三种方式来处理这种情况:suspend/resume、wait/notify/notifyAll、park/unpark。
1. suspend/resume:这种方式已经被Java弃用,因为它可能导致死锁。
2. wait/notify/notifyAll:这些方法是Object类的一部分,用于线程间的通信。当线程调用wait方法时,它会释放当前对象的所有锁,并进入等待状态。当调用notify方法时,它会唤醒一个在此对象监视器上等待的单个线程。notifyAll方法会唤醒在此对象监视器上等待的所有线程。
3. park/unpark:这些方法用于阻塞和唤醒线程。park方法会使当前线程进入阻塞状态,直到被另一个线程调用unpark方法唤醒。这种方式比suspend/resume更安全,因为它不会导致死锁。
前言
在Java中使用线程的时候肯定会有线程挂起的这种情况出现,在Java中提供了3种方式:suspend/resume、wait/notify,notifyAll、park/unpark。
1.suspend/resume
这种方式已经在Java中被弃用,因为它容易引起死锁。在使用关键字synchronized的时候如
synchronized (this) { Thread.currentThread().suspend(); }
这个时候使用resume方法是无法唤醒线程的,还有一种情况是如果在resume方法之后才进行suspend方法的调用,这个也是无法进行suspend方法的唤醒的,因为这个事件发生的顺序已经造成了死锁的出现。
2.wait/notify,notifyAll
这个是Java中常用的线程挂起方法,当调用wait方法的时候线程会自动的释放掉占有的线程资源锁,然后通过notify或notifyAll方法进行wait方法的唤醒,因此在这个地方不会出现死锁,当时如suspend/resume中提到的,如果在notify或notifyAll方法之后在进行wait操作,那么肯定也是会出现死锁的。
这里必须说明一下的是sleep方法,虽然它也能将线程挂起,但是它会产生InterruptedException异常,当sleep一定时间后它将会自动执行后面的方法,也可以通过interrupt方法进行主动打断sleep方法进行线程唤醒。
3.park/unpark
park的字面量意思是指停车场的意思,使用park来挂起线程后需要调用unpark来进行唤醒,这个没有先后顺序的区分,如果你提前进行了unpark,然后在进行park也是可以的,但是提前了的多个unpark只能看做是一个unpark,不能进行重复叠加,如果再次park的话需要新的unpark来进行唤醒操作,这个比如你在停车场进行停车操作,你如果提前进行了预约停车,你在未进入停车场之前都是可以进行多次预约的,这所有的预约只扣一次钱(unpark),但是这所有的预约操作都看作是你这一次进入停车场停车(park)的凭证,如果你离开了通过缴费凭证(unpark)一旦你想进行下一次停车,那么已经使用过的预约都不能进行作数了,你只能再次预约或者直接进入停车场,一旦要离开只能再次缴费(unpark)。
调用park/unpark使用的是LockSupport.park()/LockSupport.unpark()。
使用park/unpark的使用使用synchronized关键字也会出现死锁的情况,因为它并不释放线程所占用的锁资源,所以使用的时候也需要注意。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持自由互联。
本文共计769个文字,预计阅读时间需要4分钟。
前言:在Java中使用线程的时候,可能会遇到线程挂起的情况。Java提供了三种方式来处理这种情况:suspend/resume、wait/notify/notifyAll、park/unpark。
1. suspend/resume:这种方式已经被Java弃用,因为它可能导致死锁。
2. wait/notify/notifyAll:这些方法是Object类的一部分,用于线程间的通信。当线程调用wait方法时,它会释放当前对象的所有锁,并进入等待状态。当调用notify方法时,它会唤醒一个在此对象监视器上等待的单个线程。notifyAll方法会唤醒在此对象监视器上等待的所有线程。
3. park/unpark:这些方法用于阻塞和唤醒线程。park方法会使当前线程进入阻塞状态,直到被另一个线程调用unpark方法唤醒。这种方式比suspend/resume更安全,因为它不会导致死锁。
前言
在Java中使用线程的时候肯定会有线程挂起的这种情况出现,在Java中提供了3种方式:suspend/resume、wait/notify,notifyAll、park/unpark。
1.suspend/resume
这种方式已经在Java中被弃用,因为它容易引起死锁。在使用关键字synchronized的时候如
synchronized (this) { Thread.currentThread().suspend(); }
这个时候使用resume方法是无法唤醒线程的,还有一种情况是如果在resume方法之后才进行suspend方法的调用,这个也是无法进行suspend方法的唤醒的,因为这个事件发生的顺序已经造成了死锁的出现。
2.wait/notify,notifyAll
这个是Java中常用的线程挂起方法,当调用wait方法的时候线程会自动的释放掉占有的线程资源锁,然后通过notify或notifyAll方法进行wait方法的唤醒,因此在这个地方不会出现死锁,当时如suspend/resume中提到的,如果在notify或notifyAll方法之后在进行wait操作,那么肯定也是会出现死锁的。
这里必须说明一下的是sleep方法,虽然它也能将线程挂起,但是它会产生InterruptedException异常,当sleep一定时间后它将会自动执行后面的方法,也可以通过interrupt方法进行主动打断sleep方法进行线程唤醒。
3.park/unpark
park的字面量意思是指停车场的意思,使用park来挂起线程后需要调用unpark来进行唤醒,这个没有先后顺序的区分,如果你提前进行了unpark,然后在进行park也是可以的,但是提前了的多个unpark只能看做是一个unpark,不能进行重复叠加,如果再次park的话需要新的unpark来进行唤醒操作,这个比如你在停车场进行停车操作,你如果提前进行了预约停车,你在未进入停车场之前都是可以进行多次预约的,这所有的预约只扣一次钱(unpark),但是这所有的预约操作都看作是你这一次进入停车场停车(park)的凭证,如果你离开了通过缴费凭证(unpark)一旦你想进行下一次停车,那么已经使用过的预约都不能进行作数了,你只能再次预约或者直接进入停车场,一旦要离开只能再次缴费(unpark)。
调用park/unpark使用的是LockSupport.park()/LockSupport.unpark()。
使用park/unpark的使用使用synchronized关键字也会出现死锁的情况,因为它并不释放线程所占用的锁资源,所以使用的时候也需要注意。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持自由互联。

