学习笔记(三)Java中的锁简介

本文详细解析了锁的不同类型及其特点,包括公平锁、非公平锁、独享锁、共享锁等,并介绍了自旋锁、偏向锁等设计方案。此外,还探讨了Synchronized、RentrantLock等常见锁的应用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1、按锁的性质分
1)公平锁/非公平锁
公平锁:线程按申请锁的顺序一次获取锁;
非公平锁:不按顺序,线程可以抢占;

2)独享锁/共享锁
独享锁:锁一次只能被一个线程访问;
共享锁:锁可以被多个线程访问;

3)乐观锁/悲观锁
乐观锁:假定不发生冲突,只在提交操作时检测是否违反数据完整性;
悲观锁:假定会发生冲突,屏蔽一切可能违反数据完整性的操作;

4)可重入锁
同一个线程在外层方法获取锁的时候,进入内层方法会自动获取锁;

2、按设计方案分
1)自旋锁
尝试获取锁的线程不会立即阻塞,会循环地尝试获取锁;
优点:减少线程上下文切换的消耗;
缺点:消耗CPU;

2)偏向锁/轻量级锁/重量级锁
偏向锁:一段同步代码一直被一个线程所访问,该线程会自动获取锁,降低获取的代价;
轻量级锁:锁是偏向锁时,被另一个线程访问,升级为轻量级锁,其他线程自旋地尝试获取锁,不阻塞,提高性能;
重量级锁:锁是轻量级锁时,另一个线程自旋一定次数获取锁就进入阻塞,变为重量级锁,其他申请线程进入阻塞,性能降低;

3)分段锁
并发操作,让锁的粒度变小;

常见的锁
1)Synchronized:非公平、悲观、独享、互斥、可重入
2)RentrantLock:默认非公平、可以变公平、悲观、独享、可重入、重量级
3)ReentrantReadWriteLock:默认非公平、可以变公平、悲观、写独享、读共享、可重入、重量级

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值