贝利信息

在Java中如何使用LockSupport实现线程挂起与唤醒_LockSupport线程挂起唤醒操作解析

日期:2025-11-24 00:00 / 作者:P粉602998670
LockSupport是Java中基于许可机制的线程阻塞与唤醒工具,核心方法park()和unpark(Thread)通过Unsafe实现,无需锁即可精准控制线程,具备顺序无关性与高灵活性,广泛用于AQS等并发框架。

在Java中,LockSupport 是一个非常基础且高效的线程阻塞与唤醒工具类,位于 java.util.concurrent.locks 包下。它不像传统的 synchronizedObject.wait/notify 那样依赖对象监视器,也不像 Condition 需要配合 ReentrantLock 使用,而是直接对线程进行操作,更加灵活。

LockSupport 的核心方法

实现线程挂起与唤醒主要依赖两个静态方法:

这两个方法底层基于 Unsafe 类实现,使用了“许可”(permit)机制:每个线程最多拥有一个许可。调用 unpark 会为线程发放一个许可,而 park 会尝试消耗这个许可。如果许可已存在,park 不会阻塞;如果没有,则线程进入阻塞状态。

基本使用示例:线程挂起与唤醒

下面是一个简单的例子,展示如何使用 LockSupport 控制线程执行顺序:

public class LockSupportDemo {
    public static void main(String[] args) {
        Thread worker = new Thread(() -> {
            System.out.println("工作线程开始执行...");
            // 挂起自己
            LockSupport.park();
            System.out.println("工作线程被唤醒,继续执行任务。");
        }, "WorkerThread");

        worker.start();

        try {
            Thread.sleep(2000); // 主线程等待2秒
        } catch (InterruptedException e) {
            e.printStackTrace();
        }

        // 唤醒指定线程
        System.out.println("主线程准备唤醒工作线程。");
        LockSupport.unpark(worker);
    }
}

输出结果:

工作线程开始执行...
主线程准备唤醒工作线程。
工作线程被唤醒,继续执行任务。

注意:即使 unparkpark 之前调用,也不会失效,因为许可已经存在,后续的 park 调用会立即返回,不会阻塞。

park/unpark 的优势对比 wait/notify

相比传统的 wait/notifyLockSupport 有以下明显优点:

常见注意事项

使用 LockSupport 时需注意以下几点:

基本上就这些。LockSupport 虽然简单,却是 AQS(AbstractQueuedSynchronizer)等并发框架的基石,理解其原理有助于深入掌握 Java 并发编程。不复杂但容易忽略细节。