Java锁的分类与解析
在多线程编程中,锁是确保共享资源不会同时被多个线程访问的关键工具。Java 提供了多种锁的实现方式,可以根据不同的需求选择适合的锁。本文将从多个维度对 Java 的锁进行分类,并对每种锁的特性进行详细解析。
锁的分类
锁的分类并没有唯一标准,而是取决于观察的角度或划分的维度。从不同维度出发,可以对锁进行多种类型的划分。以下是基于常见特性(如互斥性、重入性、公平性等)的一些主流分类方式,供参考。
1. 锁的基本对比
| 锁名(例子) | 重入性 | 互斥性 | 公平性 | 分布式性 | 实现方式 | 适用场景 |
|---|---|---|---|---|---|---|
synchronized | 可重入 | 独占 | 非公平(不可配置) | 否 | 隐式锁 | 基础同步,语法简单,低并发场景 |
ReentrantLock | 可重入 | 独占 | 公平 / 非公平(默认非公平) | 否 | 显式锁 | 替代 synchronized,控制更灵活 |
ReadWriteLock | 可重入 | 写独占 / 读共享 | 公平 / 非公平(默认非公平) | 否 | 显式锁 | 读多写少,读写分离 |
StampedLock | 不可重入 | 写独占 / 读共享 | 非公平(不可配置) | 否 | 显式锁 | 高性能读多写少,需谨慎使用不可重入 |
Redis 分布式锁 | 不支持(除非设置标志) | 独占 | 非公平(不可配置) | 是 | 显式锁 | 分布式场景下的互斥控制(使用 Redisson 等库) |
Zookeeper 分布式锁 | 不支持(除非设置标志) | 独占 | 非公平(不可配置) | 是 | 显式锁 | 分布式场景下的互斥控制(使用 Curator 等库) |
2. 锁的类型与特性分析
2.1 重入性(同一线程)
- 可重入锁:同一线程如果已经持有锁,【再次请求该锁不会】导致阻塞或死锁。例如,
ReentrantLock支持重入,即线程可以在持有锁的情况下再次请求锁。 - 不可重入锁:同一线程如果已经持有锁,【再次请求该锁会】导致线程被阻塞,直到该锁被释放。
StampedLock就是不支持重入的锁。
2.2 互斥性(多线程)
- 独占锁:同一时刻【只有一个线程】可以获取锁,其他线程必须等待锁被释放才能获得锁。这种锁适用于需要保证资源不被并发访问的场景。
- 共享锁:同一时刻【多个线程】可以获取锁,通常适用于【读操作】。例如,
ReadWriteLock提供了共享锁,允许多个线程同时读取共享数据,但写操作是独占的。
2.3 公平性(多线程)
- 公平锁:按照线程请求的【时间先后顺序分配锁】,避免某些线程长时间得不到锁,避免饥饿现象。例如,
ReentrantLock可以配置为公平锁。 - 非公平锁:锁释放后,所有线程尝试【竞争锁】,谁先获得锁由线程调度决定,【不按请求时间先后顺序分配】。这可能导致部分线程长时间等待。
synchronized与默认的ReentrantLock属于非公平锁。
2.4 分布式性(多进程)
- 分布式锁:分布式锁是用于【多个进程】之间实现互斥访问的锁,确保在分布式系统中不同进程对共享资源的访问是互斥的。分布式锁通常依赖外部的分布式协调系统来实现,如 Zookeeper、Redis、etcd 等。
- 非分布式锁:非分布式锁是只在【单个进程】内使用的锁,主要用于控制同一进程中的多个线程之间的访问互斥。它无法跨进程或跨节点进行资源同步,限制了它的适用范围。
2.5 实现方式(锁管理主体)
- 隐式锁:锁的管理由【系统(如 JVM)】自动完成控制锁的获取和释放。
synchronized是最典型的隐式锁,开发者仅通过简单的代码块来控制同步。 - 显式锁:锁的管理由开发者通过明确的代码控制,通常是通过实现
Lock接口的类来控制锁的获取与释放,【开发者】必须显式地控制锁的获取与释放。ReentrantLock和ReadWriteLock是典型的显式锁。
3. 锁的应用场景
- 基础同步:
synchronized适用于简单的同步需求,语法简洁,但在高并发场景下可能不够灵活。 - 灵活控制:
ReentrantLock提供了更高的灵活性,可以指定锁的公平性,支持条件变量等功能。 - 读多写少:
ReadWriteLock适用于读多写少的场景,可以提升读操作的并发度。 - 高性能场景:
StampedLock适用于对性能要求较高的场景,尤其是在读多写少的环境下。 - 分布式锁:
Redis和Zookeeper分布式锁适用于分布式环境中的互斥控制,确保分布式系统中的数据一致性。
总结
Java 提供了多种类型的锁来满足不同场景下的并发需求。从 synchronized 到 ReentrantLock,再到分布式锁如 Redis 和 Zookeeper,每种锁都有其适用的场景和优势。在选择锁的实现方式时,开发者需要根据实际的业务需求、并发量、性能要求等因素做出合理的选择。
相关文章:
Java锁的分类与解析
在多线程编程中,锁是确保共享资源不会同时被多个线程访问的关键工具。Java 提供了多种锁的实现方式,可以根据不同的需求选择适合的锁。本文将从多个维度对 Java 的锁进行分类,并对每种锁的特性进行详细解析。 锁的分类 锁的分类并没有唯一标…...
PyTorch生成式人工智能实战(1)——神经网络与模型训练过程详解
PyTorch生成式人工智能实战(1)——神经网络与模型训练过程详解 0. 前言1. 传统机器学习与人工智能2. 人工神经网络基础2.1 人工神经网络组成2.2 神经网络的训练 3. 前向传播3.1 计算隐藏层值3.2 执行非线性激活3.3 计算输出层值3.4 计算损失值3.5 实现前…...
基于X86/Nvidia+FPGA大模型具身智能机器人控制器解决方案,同时拥有算力与实时的便利
2025年成为人形机器人产业化元年,行业已突破早期实验室研发阶段,进入"场景验证量产爬坡"新周期,预计2031年具身智能市场规模有望突破万亿元。这一进程的背后,是硬件算力、实时控制、环境适应等底层技术的系统性突破——…...
使用 OpenRewrite 简化 Java 和 SpringBoot 迁移
大家好,这里是架构资源栈!点击上方关注,添加“星标”,一起学习大厂前沿架构! 移民的挑战 随着 Spring Boot 2.x 等旧版本即将到期且不再获得支持,迁移到较新版本对于安全性、兼容性和性能改进至关重要。但…...
2025中国移动云智算大会回顾:云智变革,AI+跃迁
4月10日,2025中国移动云智算大会在苏州举办。会上,中国移动开启“由云向智”新范式,以“智”为核心开辟算网新生态,彰显其在AI新时代的战略远见与技术引领力。 “云智算”将如何通过算网基础设施与人工智能核心技术的深度融合&am…...
ubuntu 2204 安装 vcs 2023
系统 : Ubuntu 22.04.1 LTS vcs 软件 : 有已经安装好的软件(位于redhat8.10),没找到安装包 . 安装好的目录文件 占用 94 G注意 : 该虚拟机(包括安装好的软件)有114G,其中安装好的目录文件占用94GB // 即 我要把 这里 已经安装好的软件(包括scl/vcs/verdi 和其他软件) 在 …...
C#实例化类型详解:从概念到实战
在C#编程中,实例化类型是构建程序的核心操作。本文将通过通俗易懂的案例,深入解析类型实例化的原理与实践技巧,帮助开发者快速掌握这一基础但至关重要的概念。 实例化类型是什么? 定义 通过类型模板创建具体对象的过程称为实例…...
Redis的Key的过期策略
我们都知道Redis的键值对是可以设置过期时间的,那么就会涉及到一个问题,Redis到底是如何做到响应快的同时有能快速地释放掉过期的键值对的呢?不卖关子了,直接说答案,那就是Redis两个策略:定期删除和惰性删除…...
python爬虫降低IP封禁,python爬虫除了使用代理IP和降低请求频率,还有哪些方法可以应对IP封禁?
文章目录 前言1. 利用 CDN 节点2. 模拟真实用户行为3. 使用 IP 池轮换策略4. 处理 Cookie 和会话信息5. 分布式爬虫 前言 除了使用代理 IP 和降低请求频率,以下这些方法也能应对 IP 封禁: Python 3.13.2安装教程(附安装包)Python…...
Unity URP Moblie AR示例工程,真机打包出来,没阴影
效果: unity ar示例演示 现象: 真机打包测试私活没有阴影 Unity版本:2022.3.4f1c1 分析原因: Prefab :ARFeatheredPlane中也有材质,一个用于环境遮挡,一个用于阴影接受。 按理说有啊。 urp …...
单片机 | 基于51单片机的自动循迹小车设计
以下是一个基于51单片机的自动循迹小车设计详解,包含原理、公式和完整代码: 一、系统原理 核心模块: 传感器:红外对管(TCRT5000)x4主控芯片:STC89C52RC(51单片机)电机驱动:L298N驱动模块电源:7.4V锂电池(电机) + 5V稳压(单片机)工作原理: 红外对管发射红外线,…...
【AI】——结合Ollama、Open WebUI和Docker本地部署可视化AI大语言模型
🎼个人主页:【Y小夜】 😎作者简介:一位双非学校的大三学生,编程爱好者, 专注于基础和实战分享,欢迎私信咨询! 🎆入门专栏:🎇【MySQL࿰…...
Hook插件
hook插件 1.概念 在JavaScript中,hook是一种能够拦截和修改函数或方法行为的技术。通过使用hook,开发者可以在现有的函数执行前、执行后或者替换函数的实现逻辑。hook目的是找到函数入口以及一些参数变化,便于分析js逻辑。 2.hook的作用&a…...
双 Token 与 单 Token 优缺点
双Token与单Token认证机制对比 在Web应用开发中,身份认证和授权是保障系统安全的核心环节。随着技术演进,基于Token的认证机制逐渐取代传统Session方案,而双Token与单Token架构的选型争议也日益成为开发者关注的焦点。本文将从技术原理、优缺…...
Android 不插SIM卡,手机不能拨打紧急电话;2g+gsm配置才支持112紧急拨号
[DESCRIPTION] 不插SIM卡,手机不能拨打紧急电话 Root Cause 手机没有写入合法的IMEI;或者当地的某个运营商不支持紧急电话,而手机正好选上了这个运营商;或者当地的某个运营商不支持无SIM卡的紧急电话,而手机正好选上了这个运营商 [SOLUTION] …...
java 多线程之Worker Thread模式(Thread Pool模式)
Worker Thread模式 Worker的意思是工作的人,在Worker Thread模式中,工人线程Worker thread会逐个取回工作并进行处理,当所有工作全部完成后,工人线程会等待新的工作到来。 Worker Thread模式也被成为Background Threadÿ…...
在 MoonBit 中引入 Elm 架构:用简单原则打造健壮的 Web 应用
Elm 是一种纯函数式编程语言,专为构建前端 Web 应用程序而设计。它编译为 JavaScript,强调简洁性、性能和健壮性。 纯函数式的含义是函数没有副作用,这使得代码更易于理解和调试。通过强大的静态类型检查,Elm 确保应用程序不会抛…...
CMD命令行笔记
CMD命令行笔记,涵盖常用命令及实用技巧,适合快速查阅: 一、基础操作 打开CMD Win R → 输入 cmd → 回车管理员模式:右键开始菜单 → 选择“命令提示符(管理员)” 常用命令 help:查看所有命令…...
Python自动化办公
第五篇:Python自动化办公:10行代码搞定重复性工作 适合读者:职场人士、数据分析师 | 阅读时长:12分钟 引言 每天重复处理Excel、PDF或邮件?Python可以帮你自动化这些枯燥任务,节省90%的时间。本文通过实际…...
PDF 转换为 Word、HTML、LaTeX 和 Markdown 格式
PDF 转换为 Word、HTML、LaTeX 和 Markdown 格式 1. Doc2XReferences https://doc2x.com/ 1. Doc2X References [1] Yongqiang Cheng, https://yongqiang.blog.csdn.net/ [2] GPT 学术优化 (GPT Academic), https://github.com/binary-husky/gpt_academic [3] 学术版 GPT 网页…...
C#中async await异步关键字用法和异步的底层原理
目录 C#异步编程一、异步编程基础二、异步方法的工作原理三、代码示例四、编译后的底层实现五、总结 C#异步编程 一、异步编程基础 异步编程是啥玩意儿 就是让程序在干等着某些耗时操作(比如等网络响应、读写文件啥的)的时候,能把线程腾出来…...
shardingsphere-jdbc集成Seata分布式事务
1、导入相关依赖 <!-- shardingsphere-jdbc --><dependency><groupId>org.apache.shardingsphere</groupId><artifactId>shardingsphere-jdbc</artifactId><version>5.5.1</version></dependency><!-- shardingspher…...
华为OD机试真题——统计匹配的二元组个数(2025A卷:100分)Java/python/JavaScript/C++/C语言/GO六种最佳实现
2025 A卷 100分 题型 本文涵盖详细的问题分析、解题思路、代码实现、代码详解、测试用例以及综合分析; 并提供Java、python、JavaScript、C、C语言、GO六种语言的最佳实现方式! 2025华为OD真题目录全流程解析/备考攻略/经验分享 华为OD机试真题《统计匹配…...
CSS 表格样式学习笔记
CSS 提供了强大的工具来美化和定制 HTML 表格的外观。通过合理使用 CSS 属性,可以使表格更加美观、易读且功能强大。以下是对 CSS 表格样式的详细学习笔记。 一、表格边框 1. 单独边框 默认情况下,表格的 <table>、<th> 和 <td> 元…...
MySQL表的增删改查进阶版
Mysql 1、数据库的约束1.1约束类型1.2 NULL约束1.3 UNIQUE:唯一约束1.4 DEFAULT:默认值约束1.5 PRIMARY KEY:主键约束(重点)1.6 FOREIGN KEY:外键约束(重点) 2.表的设计2.1一对一2.2…...
记录 | Pycharm中如何调用Anaconda的虚拟环境
目录 前言一、步骤Step1 查看anaconda 环境名Step2 Python项目编译器更改 更新时间 前言 参考文章: 参考视频:如何在pycharm中使用Anaconda创建的python环境 自己的感想 这里使用的Pycharm 2024专业版的。我所使用的Pycharm专业版位置:【仅用…...
2025年K8s最新高频面试题
目录 Kubernetes的核心组件有哪些,各自作用是什么? Pod和Deployment的区别? Service有哪些类型,分别适用于什么场景? ConfigMap和Secret有什么区别? StatefulSet 和 Deployment 的主要区别是什么? 什么是 Ingress,有哪些常用实现方式? 如何限制 Kubernetes 中 Pod …...
【Android】LiveData深度解析
一,概述 1,LiveData是状态订阅组件,是粘性的,而非事件订阅组件(可以没有事件,但不能没有状态)。所谓的状态,即UI状态,同一时刻只存在一种,且是最新状态,过期的状态应该被遗弃。事件,则是生产者创建的事件,需一一消费,不能被遗弃。 2,Android页面承载组件Activ…...
数据结构专题 - 线性表
线性表是数据结构中最基础、最常用的数据结构之一,它在实际应用中非常广泛。无论是操作系统中的内存管理,还是数据库中的索引结构,线性表都扮演着重要角色。 一、线性表的概念与抽象数据类型 1.1 线性表的逻辑结构 线性表是由n(…...
上门送水小程序区域代理模块框架设计
一、逻辑分析 代理申请流程: 潜在代理商通过小程序提交代理申请,需要填写个人或企业基本信息、联系方式、期望代理区域等。系统收到申请后,进行初步审核,检查信息的完整性和合规性。运营人员进行人工审核,根据公司政策…...
