LockSupport.park()和unpark()提供线程阻塞与唤醒机制,不依赖synchronized,基于许可实现,避免丢失唤醒,支持精确唤醒指定线程,是AQS等同步组件的基础。

在Java中,LockSupport.park() 和 LockSupport.unpark() 是用于线程阻塞与唤醒的底层工具,它们由JUC(java.util.concurrent)包提供,比传统的 wait/notify 更加灵活且不易出错。这两个方法直接作用于线程,不依赖 synchronized 或 monitor 锁,适合实现自定义同步器或高级并发控制。
LockSupport.park() 会使当前线程进入等待状态,直到其他线程调用 LockSupport.unpark(thread) 将其唤醒,或者当前线程被中断。
LockSupport.unpark(Thread thread) 可以唤醒指定的线程。如果目标线程尚未阻塞,下次调用 park 时会直接返回(许可机制),避免了 lost wake-up 问题。
下面这个例子展示了即使先调用 unpark,后续的 park 也不会阻塞:
立即学习“Java免费学习笔记(深入)”;
Thread t = new Thread(() -> {
System.out.println("即将 park");
LockSupport.park(); // 不会阻塞,因为已有许可
System.out.println("已恢复运行");
});
// 先发放许可
LockSupport.unpark(t);
t.start();
输出结果为:
免费 盛世企业网站管理系统(SnSee)系统完全免费使用,无任何功能模块使用限制,在使用过程中如遇到相关问题可以去官方论坛参与讨论。开源 系统Web代码完全开源,在您使用过程中可以根据自已实际情况加以调整或修改,完全可以满足您的需求。强大且灵活 独创的多语言功能,可以直接在后台自由设定语言版本,其语言版本不限数量,可根据自已需要进行任意设置;系统各模块可在后台自由设置及开启;强大且适用的后台管理支
0
即将 park 已恢复运行
这是因为 unpark 提供了一个“许可”,park 会消费这个许可并立即返回。
使用 park/unpark 可以精确地控制哪个线程被唤醒,不像 notify 随机唤醒一个等待线程。
Thread worker = new Thread(() -> {
System.out.println("工作线程开始执行任务");
System.out.println("工作线程准备 park");
LockSupport.park();
System.out.println("工作线程被唤醒,继续执行");
});
worker.start();
// 主线程休眠一会儿,确保 worker 先启动
try { Thread.sleep(1000); } catch (InterruptedException e) {}
System.out.println("主线程调用 unpark 唤醒工作线程");
LockSupport.unpark(worker);
输出顺序清晰,能保证 worker 被正确唤醒。
基本上就这些。LockSupport 的设计简洁高效,是 AQS(AbstractQueuedSynchronizer)等高级同步组件的基础。掌握它有助于理解 Java 并发底层机制,也能在特定场景下写出更精准的线程协作逻辑。
以上就是如何在Java中使用LockSupport.park与unpark的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号