LockSupport.park()和unpark()提供线程阻塞与唤醒机制,不依赖synchronized,基于许可实现,避免丢失唤醒,支持精确唤醒指定线程,是AQS等同步组件的基础。
在Java中,LockSupport.park() 和 LockSupport.unpark() 是用于线程阻塞与唤醒的底层工具,它们由JUC(java.util.concurrent)包提供,比传统的 wait/notify 更加灵活且不易出错。这两个方法直接作用于线程,不依赖 synchronized 或 monitor 锁,适合实现自定义同步器或高级并发控制。

LockSupport.unpark(Thread thread) 可以唤醒指定的线程。如果目标线程尚未阻塞,下次调用 park 时会直接返回(许可机制),避免了 lost wake-up 问题。
下面这个例子展示了即使先调用 unpark,后续的 park 也不会阻塞:
Thread t = new Thread(() -> {
System.out.println("即将 park");
LockSupport.park(); // 不会阻塞,因为已有许可
System.out.println("已恢复运行");
});
// 先发放许可
LockSupport.unpark(t);
t.start();
输出结果为:
即将 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 并发底层机制,也能在特定场景下写出更精准的线程协作逻辑。