首页 > Java > java教程 > 正文

Java中如何使用LockSupport实现线程挂起与唤醒

P粉602998670
发布: 2025-10-22 18:03:01
原创
975人浏览过
LockSupport是Java中用于线程阻塞与唤醒的基础工具,基于许可机制实现。1. 核心方法为park()和unpark(Thread),前者使当前线程阻塞,后者唤醒指定线程。2. 每个线程最多持有一个许可,unpark发放许可,park尝试消耗许可,无许可则阻塞。3. 与wait/notify不同,park/unpark无需synchronized,可精确唤醒指定线程且不会丢失唤醒信号。4. 即使unpark在park前调用,后续park仍可立即返回,具有顺序无关性。5. park被中断时不会抛出异常,但可通过Thread.interrupted()检测中断状态。6. 支持带阻塞原因的park(Object blocker),便于线程诊断和dump分析。7. 广泛应用于ReentrantLock、FutureTask等并发组件底层,是构建高级同步机制的基础。

java中如何使用locksupport实现线程挂起与唤醒

在Java中,LockSupportjava.util.concurrent.locks 包下的一个工具类,用于创建更高级的同步组件。它提供了最基本的线程阻塞和唤醒能力,底层被 ReentrantLockFutureTask 等广泛使用。

LockSupport的核心方法

LockSupport 主要通过两个静态方法来实现线程的挂起与唤醒:

  • LockSupport.park():挂起当前线程,直到收到唤醒信号或其他中断。
  • LockSupport.unpark(Thread thread):唤醒指定的线程。

这两个方法基于“许可”(permit)机制,每个线程最多拥有一个许可。调用 unpark 会为线程发放一个许可;调用 park 会尝试消耗这个许可并立即返回,如果没有许可,则线程被阻塞,等待许可到来。

基本使用示例

下面是一个简单的线程挂起与唤醒的例子:

立即学习Java免费学习笔记(深入)”;

如知AI笔记
如知AI笔记

如知笔记——支持markdown的在线笔记,支持ai智能写作、AI搜索,支持DeepseekR1满血大模型

如知AI笔记 27
查看详情 如知AI笔记
public class LockSupportDemo {
    public static void main(String[] args) throws InterruptedException {
        Thread t = new Thread(() -> {
            System.out.println("子线程 " + Thread.currentThread().getName() + " 开始运行");
            
            // 挂起自己
            System.out.println("子线程即将 park");
            LockSupport.park();

            System.out.println("子线程被唤醒,继续执行");
        });

        t.start();

        // 主线程休眠1秒,确保子线程先执行到 park
        Thread.sleep(1000);

        System.out.println("主线程调用 unpark 唤醒子线程");
        LockSupport.unpark(t); // 唤醒线程t

        t.join(); // 等待子线程结束
    }
}
登录后复制

输出结果:

子线程 Thread-0 开始运行 子线程即将 park 主线程调用 unpark 唤醒子线程 子线程被唤醒,继续执行

park 和 unpark 的特点

  • 顺序无关:即使 unparkpark 之前调用,park 也不会阻塞,因为它已经有许可了。
  • 不会丢失唤醒:相比 Object.wait() 必须在 synchronized 块中使用且容易因时序问题导致丢失通知,LockSupport 更安全可靠。
  • 可响应中断但不抛异常park 被中断时不会抛出 InterruptedException,但可以通过 Thread.interrupted() 检查中断状态。

带诊断信息的 park

可以使用 LockSupport.park(Object blocker) 提供阻塞原因,便于调试和分析线程 dump:

LockSupport.park("Waiting for data"); // 在线程dump中会显示这个信息
登录后复制

该信息可通过 Thread.getLockInfo() 或监控工具查看,对排查死锁或长时间阻塞很有帮助。

与 wait/notify 的对比

  • wait/notify 必须在 synchronized 块中使用,而 LockSupport.park/unpark 没有此限制。
  • unpark 可以精确唤醒指定线程,notify 则是随机唤醒一个。
  • park 不会像 wait 那样自动释放锁,它本身就是低级原语。

基本上就这些。LockSupport 是构建锁和同步器的基础,简单但强大。

以上就是Java中如何使用LockSupport实现线程挂起与唤醒的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号