java 各种锁

Java 中的各种锁    引用自https://www.cnblogs.com/cag2050/p/12357844.html

锁的种类概念实现
悲观锁(阻塞同步)   synchronized、
乐观锁(非阻塞同步) 目前,在Java中应用最广泛的非阻塞同步就是CAS CAS包装类:AtomicXXX、
公平锁 公平锁是指多个线程在等待同一个锁时,必须按照申请锁的时间顺序来依次获得锁;而非公平锁则不保证这一点,在锁被释放时,任何一个等待锁的线程都有机会获得锁。 ReentrantLock提供了公平锁和非公平锁的实现;
公平锁:ReentrantLock pairLock = new ReentrantLock(true);
非公平锁:ReentrantLock pairLock = new ReentrantLock(false);如果构造函数不传递参数,则默认是非公平锁。
非公平锁   synchronized
独占锁(是一种悲观锁) 锁只能被单个线程持有 ReentrantLock
共享锁(是一种乐观锁) 锁能被多个线程共同持有 ReadWriteLock(整体思路是它有两把锁,第 1 把锁是写锁,获得写锁之后,既可以读数据又可以修改数据,而第 2 把锁是读锁,获得读锁之后,只能查看数据,不能修改数据。读锁可以被多个线程同时持有,所以多个线程可以同时查看数据)
可重入锁   synchronized、
自旋锁
分类:
自适应的自旋锁:自适应意味着自旋的时间不再是固定的了;
如果物理机器有一个以上的处理器或处理器核心,能让两个或以上的线程同时并行执行,我们就可以让后面请求锁的那个线程“稍等一会”,但不放弃处理器的执行时间,看看只有持有锁的线程是否很快就会释放锁。
为了让线程等待,我们只须让线程执行一个忙循环(自旋),这项技术就是所谓的自旋锁。(《深入理解Java虚拟机(第3版)》,第479页)
 
重量级锁 使用操作系统互斥量来实现的传统锁  
轻量级锁 它设计的初衷是在没有多线程竞争的前提下,减少传统的重量级锁使用操作系统互斥量产生的性能消耗。
如果出现两条以上的线程争用同一个锁的情况,那轻量级锁就不再有效,必须要膨胀为重量级锁。
轻量级锁是在无竞争的情况下使用CAS操作去消除同步使用的互斥量。
 
偏向锁 偏向锁的目的是:消除数据在无竞争情况下的同步原语,进一步提高程序的运行性能。
偏向锁是在无竞争情况下把整个同步都消除掉,连CAS操作都不去做了。
偏向锁会偏向于第一个获得它的线程,如果在接下来的执行过程中,该锁一直没有被其他的线程获取,则持有偏向锁的线程将永远不需要再进行同步。
一旦出现另外一个线程去尝试获取这个锁的情况,偏向模式就马上宣告结束。
 

内容来源:《深入理解Java虚拟机(第3版)》

posted @   雪域飞魂  阅读(47)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
阅读排行:
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 单元测试从入门到精通
· winform 绘制太阳,地球,月球 运作规律
· 上周热点回顾(3.3-3.9)
点击右上角即可分享
微信分享提示