LockSupport工具类

什么是LockSupport

LockSupportJUC中的一个线程阻塞工具 ,主要提供线程的暂停(park)唤醒(unpark)

它具有以下几个特点:

  1. 许可证机制:每个线程都有一个许可证,初始值为0
  2. 非锁依赖:不强制要求先获取锁再使用
  3. 精准控制:能够精确唤醒指定的线程
  4. 不可重入:许可证不会叠加,最多只有一个

这些特点使得LockSupport相对于传统的wait/notify更具有优势:

对比项 Object.wait()/notify() LockSupport.park()/unpark()
锁要求 必须在synchronized块内 不需要获取锁
顺序性 必须先wait后notify 可以先unpark后park
精确性 随机唤醒一个或全部线程 可指定唤醒具体线程
灵活性 较低 较高

LockSupport的实现

LockSupport是使用Unsafe类实现的,下面来看LockSupport的方法

park方法

java 复制代码
public static void park(Object blocker) {
    Thread t = Thread.currentThread();
    setBlocker(t, blocker);
    U.park(false, 0L);
    setBlocker(t, null);
}

如果调用park方法的线程已经拿到了许可证,那么调用之后会马上返回,否则会被阻塞挂起。

在线程被阻塞直到被调用unpark方法或者其他线程调用了它的interrupt方法。

与线程调用waitsleep方法不同的是,通过park方法阻塞时,被其他线程中断之后不会抛出 InterruptedException移除。

unpark方法

java 复制代码
public static void unpark(Thread thread) {
    if (thread != null)
        U.unpark(thread);
}

当一个线程调用unpark时,如果传入的线程没有持有许可证,则会让传入的线程持有许可证。 如果传入的线程之前因为调用park被挂起,则它会被唤醒

相关推荐
skywalker_114 分钟前
Maven速通
java·maven
garmin Chen5 分钟前
Elasticsearch(4):Java Rest Client 搜索与聚合速查
java·分布式·elasticsearch
小旭952711 分钟前
MySQL 主从复制、MyCat 读写分离与分库分表实战
java·数据库·sql·mysql·database
计算机安禾11 分钟前
【算法分析与设计】第38篇:最近点对与分治在几何中的应用
java·服务器·网络·数据库·算法
IT_陈寒19 分钟前
Vue的动态组件坑了我整整一天!
前端·人工智能·后端
梦梦代码精19 分钟前
功能堆砌不如好扩展:4 款开源商城系统的选型思考
java·docker·uni-app·开源·php
计算机安禾21 分钟前
【算法分析与设计】第37篇:平面扫描与线段交问题
java·大数据·数据库·算法·机器学习
Cobyte22 分钟前
AI 的个人便签纸:Claude Code 的 TodoWrite 模式
前端·后端·aigc
hai31524754324 分钟前
FiveOS V3.0 交付(微服务器操作系统版 · 物理合规修正
linux·人工智能·spring boot·后端·神经网络·机器学习
兰令水26 分钟前
leecodecode【二叉树排序+最近公共祖先】【2026.6.2打卡-java版本】
java·数据结构·算法·leetcode