news 2026/3/26 14:00:12

<span class=“js_title_inner“>ReentrantLock基础用法示例</span>

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
<span class=“js_title_inner“>ReentrantLock基础用法示例</span>

ReentrantLock基础用法示例

作者:系统管理员

摘要

ReentrantLock基础用法示例


ReentrantLock 基础用法示例(完整可运行)

你需要的是 ReentrantLock 最核心的基础用法示例,我会提供可直接复制运行的代码,覆盖「基本加锁释放」「可重入特性」两个核心基础场景,并附带详细注释和运行结果说明。

一、核心基础用法(必掌握)

示例代码

import java.util.concurrent.locks.ReentrantLock; /** * ReentrantLock 基础用法示例: * 1. 基本的加锁(lock())和释放锁(unlock()) * 2. 可重入特性(同一线程多次获取同一把锁) * 3. 多线程安全保证 */ public class ReentrantLockBasicDemo { // 1. 创建 ReentrantLock 实例(默认非公平锁,性能更优) private final ReentrantLock lock = new ReentrantLock(); // 共享变量(用于验证线程安全) private int counter = 0; // 2. 核心方法:加锁执行线程安全逻辑 public void increment() { // 获取锁(阻塞式,当前线程会一直等,直到拿到锁) lock.lock(); try { // 线程安全的业务逻辑:对共享变量自增 counter++; System.out.println(Thread.currentThread().getName() + " 执行自增,counter = " + counter); // 演示可重入:同一线程调用另一个加锁方法 reentrantMethod(); } finally { // 必须在 finally 中释放锁! // 无论业务逻辑是否抛出异常,都能保证锁释放,避免死锁 lock.unlock(); } } // 3. 演示可重入的方法(同一把锁) private void reentrantMethod() { // 同一线程再次获取锁(可重入,不会死锁) lock.lock(); try { // getHoldCount():获取当前线程持有该锁的次数(重入计数) System.out.println(Thread.currentThread().getName() + " 重入锁成功,当前持有锁次数 = " + lock.getHoldCount()); } finally { // 重入的锁必须对应释放,否则计数不会归0,锁无法真正释放 lock.unlock(); } } // 测试入口 public static void main(String[] args) { ReentrantLockBasicDemo demo = new ReentrantLockBasicDemo(); // 4. 多线程测试:启动5个线程竞争锁 for (int i = 0; i < 5; i++) { new Thread(demo::increment, "线程-" + (i + 1)).start(); } } }

运行结果(示例)

线程-1 执行自增,counter = 1 线程-1 重入锁成功,当前持有锁次数 = 2 线程-2 执行自增,counter = 2 线程-2 重入锁成功,当前持有锁次数 = 2 线程-3 执行自增,counter = 3 线程-3 重入锁成功,当前持有锁次数 = 2 线程-4 执行自增,counter = 4 线程-4 重入锁成功,当前持有锁次数 = 2 线程-5 执行自增,counter = 5 线程-5 重入锁成功,当前持有锁次数 = 2

代码关键说明

  1. 锁的创建

    new ReentrantLock()默认创建非公平锁(性能优先,绝大多数场景推荐);若需公平锁,用new ReentrantLock(true)

  2. 加锁释放规范

  • lock.lock()

    :阻塞式获取锁,线程会一直等待直到拿到锁;

  • 释放锁必须放在finally块中,避免业务逻辑抛出异常导致锁泄漏;

  • 重入的锁要“获取多少次,释放多少次”(示例中increment()获取1次,reentrantMethod()再获取1次,对应释放2次)。

  • 可重入特性

    :同一线程多次调用lock()不会死锁,getHoldCount()可查看当前线程持有锁的次数(重入计数)。

  • 线程安全

    :多线程竞争下,counter自增完全有序,无线程安全问题。

  • 二、极简版基础示例(无重入,快速入门)

    如果只需要最基础的“加锁-释放”示例,可参考以下极简版本:

    import java.util.concurrent.locks.ReentrantLock; /** * ReentrantLock 极简基础示例(无重入) */ public class ReentrantLockMinimalDemo { private final ReentrantLock lock = new ReentrantLock(); private int num = 0; // 加锁执行简单逻辑 public void add() { lock.lock(); // 获取锁 try { num++; System.out.println(Thread.currentThread().getName() + ":num = " + num); } finally { lock.unlock(); // 释放锁 } } public static void main(String[] args) { ReentrantLockMinimalDemo demo = new ReentrantLockMinimalDemo(); // 启动3个线程测试 new Thread(demo::add, "T1").start(); new Thread(demo::add, "T2").start(); new Thread(demo::add, "T3").start(); } }

    运行结果(示例)

    T1:num = 1 T2:num = 2 T3:num = 3

    三、基础用法核心总结

    关键点回顾

    1. 核心规范

      :使用 ReentrantLock 必须遵循lock() → try → 业务逻辑 → finally → unlock(),这是避免死锁的核心。

    2. 可重入特性

      :同一线程可多次调用lock(),但需保证unlock()次数与lock()一致,否则锁不会真正释放。

    3. 默认特性

      :ReentrantLock 默认是非公平锁,性能优于公平锁,无需特殊场景(如排队)不要轻易用公平锁。

    4. 线程安全

      :基础用法的核心价值是保证多线程对共享资源操作的原子性,替代 synchronized 完成简单同步场景。


    原文链接: https://1024bat.cn/article/44

    来源: 淘书1024bat

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/3/16 6:45:07

deepaccident复现个人问题记录

环境4090 cuda11.3 torch1.10.2 mmcv1.4.0&#xff0c;可以跑通 问题1&#xff1a;installationDeepAccident/docs/installation.md at main tianqi-wang1996/DeepAccident​​​​​​ 要求的cuda版本是10.2&#xff0c;不兼容 RuntimeError: CUDA error: no kernel image…

作者头像 李华
网站建设 2026/3/23 10:48:47

SpringBoot Servlet 容器全解析:嵌入式配置与外置容器部署

在 SpringBoot Web 开发中&#xff0c;Servlet 容器是核心基础设施。SpringBoot 提供了两种容器使用方式&#xff1a;嵌入式容器&#xff08;默认&#xff09;和外置容器&#xff0c;前者便捷轻量&#xff0c;后者适配传统 Web 场景&#xff08;如 JSP 开发&#xff09;。本文将…

作者头像 李华
网站建设 2026/3/25 11:03:12

Mumbai: 1靶机记录

nmap端口扫描 nmap -p- -sV -T4 -A 192.168.124.130 ftp下载node文件 TODO: Move these multiple HTTP Servers running to Docker. I hear containers make things inherently secure - maybe this will shut those security researchers up. Also, dont forget to remove a…

作者头像 李华
网站建设 2026/3/17 7:35:31

FaceRecon-3D应用案例:电商虚拟试妆的3D人脸解决方案

FaceRecon-3D应用案例&#xff1a;电商虚拟试妆的3D人脸解决方案 你有没有想过&#xff0c;为什么用户在电商App里点开一款口红&#xff0c;却迟迟不下单&#xff1f;不是价格问题&#xff0c;也不是品牌信任度不够——而是“看不到上脸效果”。传统平面图、模特图、甚至AR滤镜…

作者头像 李华
网站建设 2026/3/15 19:25:07

TranslateGemma模型轻量化:嵌入式Linux系统的移植与优化

TranslateGemma模型轻量化&#xff1a;嵌入式Linux系统的移植与优化 1. 引言 在嵌入式设备上部署AI模型一直是开发者面临的挑战之一。Google最新开源的TranslateGemma模型以其轻量化和高效性&#xff0c;为嵌入式Linux系统上的多语言翻译任务提供了新的可能性。本文将带你一步…

作者头像 李华