java中的locksupport_详解Java多线程编程中LockSupport

LockSupport是Java并发库中用于创建锁和其他同步类的基础工具,提供park()和unpark()方法来阻塞和解除线程。与Thread.suspend/resume不同,它避免了死锁问题,因为park()和unpark()涉及到许可的概念。当许可可用时,线程调用park()不会阻塞;否则,线程会被阻塞,直到其他线程调用unpark()。如果线程在未获得许可的情况下连续调用park(),它将一直阻塞。此外,park()方法对中断具有响应性,但不会抛出InterruptedException。了解LockSupport有助于深入理解Java并发机制。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

LockSupport是用来创建锁和其他同步类的基本线程阻塞原语。

LockSupport中的park() 和 unpark() 的作用分别是阻塞线程和解除阻塞线程,而且park()和unpark()不会遇到“Thread.suspend 和 Thread.resume所可能引发的死锁”问题。

因为park() 和 unpark()有许可的存在;调用 park() 的线程和另一个试图将其 unpark() 的线程之间的竞争将保持活性。

基本用法LockSupport 很类似于二元信号量(只有1个许可证可供使用),如果这个许可还没有被占用,当前线程获取许可并继 续 执行;如果许可已经被占用,当前线 程阻塞,等待获取许可。

运行该代码,可以发现主线程一直处于阻塞状态。因为 许可默认是被占用的 ,调用park()时获取不到许可,所以进入阻塞状态。

如下代码:先释放许可,再获取许可,主线程能够正常终止。LockSupport许可的获取和释放,一般来说是对应的,如果多次unpark,只有一次park也不会出现什么问题,结果是许可处于可用状态。

LockSupport是可不重入 的,如果一个线程连续2次调用 LockSupport .park(),那么该线程一定会一直阻塞下去。

这段代码打印出a和b,不会打印c,因为第二次调用park的时候,线程无法获取许可出现死锁。

下面我们来看下LockSupport对应中断的响应性

最终线程会打印出thread over.true。这说明 线程如果因为调用park而阻塞的话,能够响应中断请求(中断状态被设置成true),但是不会抛出InterruptedException 。

LockSupport函数列表

LockSupport示例对比下面的“示例1”和“示例2”可以更清晰的了解LockSupport的用法。

示例1

示例2

运行结果:

说明:park和wait的区别。wait让线程阻塞前,必须通过synchronized获取同步锁。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值