Java学习手册:Java锁的分类和特点

本文详细介绍了Java中的锁机制,包括公平锁与非公平锁、可重入锁、独享锁与共享锁、互斥锁与读写锁、乐观锁与悲观锁、分段锁、偏向锁、轻量级锁、重量级锁和自旋锁。讲解了各种锁的特点和适用场景,如公平性、重入性、读写分离、锁升级和线程中断等概念,帮助开发者更好地理解和运用Java并发控制。
摘要由CSDN通过智能技术生成

一、公平锁、非公平锁

公平锁指多个线程按照申请锁的顺序来获取锁,,即按等待获取锁的线程的等待时间进行获取,等待时间长的具有优先获取锁的权利;非公平锁就是没有顺序完全随机,所以能会造成优先级反转或者饥饿现象 。synchronized 就是非公平锁,ReentrantLock(使用 CAS 和 AQS 实现)通过构造参数可以决定是非公平锁还是公平锁,默认构造是非公平锁。非公平锁的吞吐量性能比公平锁好。


二、可重入锁

又名递归锁,指在同一个线程在外层方法获取锁的时候在进入内层方法会自动获取锁,synchronized 和 ReentrantLock 都是可重入锁,可重入锁可以在一定程度避免死锁


三、独享锁、共享锁

独享锁是指该锁一次只能被一个线程持有,共享锁指该锁可以被多个线程持有。synchronized 和 ReentrantLock 都是独享锁,ReadWriteLock 的读锁是共享锁,写锁是独占锁。ReentrantLock 的独享锁和共享锁也是通过 AQS 来实现的。


四、互斥锁、读写锁

互斥锁,指的是一次最多只能有一个线程持有的锁。对于互斥锁,如果资源已被占用,资源申请者只能进入睡眠状态。互斥锁实质就是 ReentrantLock,读写锁实质就是 ReadWriteLock。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值