如何在Java中使用LockSupport控制线程

LockSupport通过park和unpark实现线程阻塞与唤醒,支持中断响应且可传递诊断信息,常用于构建高级同步器如AQS。

如何在java中使用locksupport控制线程

在Java中,LockSupport 是一个非常底层的线程阻塞与唤醒工具类,位于 java.util.concurrent.locks 包下。它不像 synchronized 或 ReentrantLock 那样提供显式的锁机制,而是直接对线程进行“停车”和“发车”操作,常用于构建更高级的同步器,比如 AQS(AbstractQueuedSynchronizer)。下面介绍如何使用 LockSupport 来控制线程的挂起与唤醒。

基本用法:park 和 unpark

LockSupport 的核心方法是两个静态方法:

LockSupport.park():阻塞当前线程,直到收到唤醒信号。 LockSupport.unpark(Thread thread):唤醒指定的线程。

与 wait/notify 不同,unpark 可以在 park 之前调用,相当于“预发通行证”。如果线程已经持有许可,park 调用会立刻返回,不会阻塞。

示例代码:

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

Thread t = new Thread(() -> {    System.out.println("线程即将 park");    LockSupport.park();    System.out.println("线程被唤醒");});t.start();// 主线程休眠1秒,确保子线程先执行try { Thread.sleep(1000); } catch (InterruptedException e) {}System.out.println("主线程调用 unpark");LockSupport.unpark(t);

输出结果:

线程即将 park主线程调用 unpark线程被唤醒

支持中断但不抛异常

调用 park() 的线程如果被中断,不会抛出 InterruptedException,但会立即返回。可以通过 Thread.interrupted() 检查中断状态。

例如:

Thread t = new Thread(() -> {    System.out.println("进入 park");    LockSupport.park();    if (Thread.interrupted()) {        System.out.println("线程被中断了");    }    System.out.println("继续执行");});

注意:interrupted() 是清除中断状态的方法,慎用。

park 时携带诊断信息

你可以传入一个“阻塞原因”对象给 park 方法,便于调试线程状态:

LockSupport.park("等待资源释放");

这个信息可以在 JVM 线程转储(thread dump)中看到,有助于排查问题。

避免死锁和误用

虽然 LockSupport 很灵活,但也容易误用:

没有重入概念,多次 park 会一直阻塞。 unpark 只能发放一个许可,多次 unpark 同一线程也只累积一次。 不能像 synchronized 那样保证原子性,需配合其他机制使用。

常见错误:忘记 unpark 或线程已退出导致无法唤醒。

基本上就这些。LockSupport 是 Java 并发包的基石之一,理解它有助于深入掌握并发原理。用起来简单,但要小心控制线程生命周期和调用顺序。

以上就是如何在Java中使用LockSupport控制线程的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/33196.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月4日 09:22:59
下一篇 2025年11月4日 09:27:12

相关推荐

发表回复

登录后才能评论
关注微信