网站首页 > 精选教程 正文
在高并发的场景里,除了昨天谈到的最全MySQL锁,比如:行锁、表锁、悲观锁、乐观锁、共享锁,非常影响并发性能之外。
还有今天我要谈到的Java并发场景里的各种锁,锁的冲突同样是影响并发访问性能的另外一种核心因素,同样的重要,只不过一个是针对数据库的场景,另外一个是针对Java并发场景。
今天接着分享Java并发编程里的锁,这样可以形成系统的高并发锁系列,希望对大家掌握好高并发有所帮助@mikechen
独享锁 VS 共享锁
1.独享锁
是指该锁一次只能被一个线程所持有,如下图所示:
2.共享锁
共享锁是指该锁可被多个线程所持有,如下图所示:
之前这篇文章我谈过的Java读写锁ReadWriteLock原理与应用场景详解,其读锁就是共享锁。
这样设计的原因是就是尽最大的解放并发读的操作,因为读占据了更大的访问请求,我只会在涉及少部分写的操作的时候才考虑独享锁,从而提升并发的效率。
乐观锁 VS 悲观锁
悲观锁 VS 悲观锁,在Java并发编程和数据库中都有实际的应用场景。
1.悲观锁
悲观锁它认为在它修改数据之前,一定会有其它线程去修改它,所以每次在拿数据的时候都会上锁。
典型代表就是一篇我谈到的Synchronized的底层实现原理,就是典型的悲观锁。
2.乐观锁
乐观锁,顾名思义,就是很乐观,每次去拿数据的时候都认为别人不会修改。
如下图所示:
比如典型的应用就是Java并发里的CAS实现,Java并发包中的很多类都使用了CAS技术来实现乐观锁。
CAS全称 Compare And Swap,即比较与交换,就是一种乐观锁算法。
公平锁 VS 非公平锁
1.公平锁
公平锁,就是很公平,在并发环境中会按照FIFO的规则来获取锁。
如下图所示:
Java并发编程里ReentrantLock,可以指定构造函数来创建公平锁。
比如:
new ReentrantLock(true)
2.非公平锁
非公平锁就是不用正常排队来获取锁,而是上来就直接尝试占有锁。
如下图所示:
非公平锁的优点
优点:就是可以减少唤起线程的开销,整体的吞吐效率高,因为线程有几率不阻塞直接获得锁。
非公平锁的缺点
缺点就是:处于等待队列中的线程可能会饿死,或者等很久才会获得锁。
非公平锁的应用
ReentrantLock的构造函数的默认就是采用非公平锁的实现。
如下所示:
new ReentrantLock(false)
也就是说ReentrantLock里面就包含了两种锁的实现:默认就是非公平锁,可以通过修改设置true从而变成公平锁。
以上就是Java最全锁的梳理和总结,希望对大家掌握好高并发有所帮助。
-end-
阿里架构师进阶从0到1全部合集(非常全面)
- 上一篇: 5000 字 详解 Java 中的 21 种锁
- 下一篇: 大白话讲Java的锁
猜你喜欢
- 2024-11-21 Java中的重重“锁”事
- 2024-11-21 线程进阶:多任务处理——Java中的锁(Unsafe基础)
- 2024-11-21 深入理解MySQL锁机制原理
- 2024-11-21 Java并发锁的原理,你所不知道的Java“锁”事
- 2024-11-21 阿里二面:你知道Java中的同步与锁机制详解?
- 2024-11-21 知识点深度解读系列-JAVA锁
- 2024-11-21 图解Java中的锁:什么是死锁?怎么排查死锁?怎么避免死锁?
- 2024-11-21 Java锁与线程的那些“不可描述”的事儿
- 2024-11-21 让人闻风丧胆的 Mysql 锁机制
- 2024-11-21 Java中各种锁的理解
你 发表评论:
欢迎- 最近发表
- 标签列表
-
- nginx反向代理 (57)
- nginx日志 (56)
- nginx限制ip访问 (62)
- mac安装nginx (55)
- java和mysql (59)
- java中final (62)
- win10安装java (72)
- java启动参数 (64)
- java链表反转 (64)
- 字符串反转java (72)
- java逻辑运算符 (59)
- java 请求url (65)
- java信号量 (57)
- java定义枚举 (59)
- java字符串压缩 (56)
- java中的反射 (59)
- java 三维数组 (55)
- java插入排序 (68)
- java线程的状态 (62)
- java异步调用 (55)
- java中的异常处理 (62)
- java锁机制 (54)
- java静态内部类 (55)
- java怎么添加图片 (60)
- java 权限框架 (55)
本文暂时没有评论,来添加一个吧(●'◡'●)