LockSupport是Java中用于线程阻塞与唤醒的底层工具,通过park()和unpark()方法实现线程的精确控制,无需依赖锁机制,支持许可预存且可指定唤醒目标线程,常用于构建高级同步组件如AQS、自定义门闩等并发结构。

在Java中,LockSupport 是一个非常底层的线程阻塞与唤醒工具类,位于 java.util.concurrent.locks 包下。它不像 synchronized 或 ReentrantLock 那样提供锁机制,而是直接对线程进行阻塞(park)和唤醒(unpark)操作,是实现更高级同步器(如 AQS)的基础。
park() 方法会让当前线程进入等待状态,直到发生以下情况之一:
unpark(Thread thread) 方法可以唤醒指定线程,即使该线程尚未调用 park(),也会“预存”一次许可,使得下一次 park() 调用不会真正阻塞。
这与 Object 的 wait()/notify() 有本质区别:wait 必须在 synchronized 块中执行,且 notify 只能唤醒一个等待中的线程但无法指定具体线程;而 LockSupport 可以精确控制哪个线程被唤醒,且不需要获取监视器锁。
立即学习“Java免费学习笔记(深入)”;
下面是一个简单的例子,展示主线程启动一个子线程,子线程立即阻塞,主线程稍后将其唤醒:
import java.util.concurrent.locks.LockSupport;
public class LockSupportDemo {
public static void main(String[] args) throws InterruptedException {
Thread worker = new Thread(() -> {
System.out.println("子线程准备阻塞");
LockSupport.park(); // 阻塞自己
System.out.println("子线程被唤醒");
});
worker.start();
Thread.sleep(1000); // 等待子线程启动并进入阻塞
System.out.println("主线程即将唤醒子线程");
LockSupport.unpark(worker); // 唤醒指定线程
worker.join();
}
}
输出结果为:
子线程准备阻塞相比传统的 wait/notify,LockSupport 具有以下优点:
需要注意的几点:
LockSupport 常用于自定义同步组件中,比如实现一个简单的信号量或任务调度器。以下是一个模拟“一次性门闩”的例子:
public class OneTimeLatch {
private volatile boolean triggered = false;
private Thread waitingThread;
public void await() {
if (!triggered) {
waitingThread = Thread.currentThread();
LockSupport.park();
}
}
public void trigger() {
triggered = true;
if (waitingThread != null) {
LockSupport.unpark(waitingThread);
}
}
}
这个简易门闩允许多个线程调用 await() 等待,trigger() 触发后释放等待线程。虽然功能类似 CountDownLatch,但展示了 LockSupport 在构建同步原语中的灵活性。
基本上就这些。LockSupport 提供了比传统机制更灵活、更底层的线程控制能力,适合在开发并发框架或需要精细控制线程行为的场景中使用。掌握它的使用有助于深入理解 Java 并发底层原理。
以上就是在Java中如何使用LockSupport实现线程阻塞与唤醒_LockSupport操作实践的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号