品易云推流 关闭
文章 > java基础 > java悲观锁和乐观锁的比较

java悲观锁和乐观锁的比较

java

头像

小妮浅浅

2021-04-09 16:52:13787浏览 · 0收藏 · 0评论

1、悲观锁,顾名思义,是悲观的,觉得不锁柱的资源会被别人的线程抢走,所以悲观锁每次获取和修改数据都会锁定数据。

典型的悲观锁案例:synchronized关键词和Lock接口。

2、乐观锁,认为自己在操作资源时不会有其他线程干扰,所以不会锁定对象,只是在更新资源时会去对比一下我修改过的数据之间是否有其他线程修改过的数据。若无修改,此次修改正常,若有其他线程修改,则放弃此次修改,并选择报错或重试。这是一个基于冲突检测的并发策略,这种并发策略的实现不需要线程挂起,因此是非阻塞同步。乐观主义锁一般采用CAS算法实现。

典型的乐观锁案例:Java并发包Atomic原子类,数据库version版本机制。

3、悲观锁与乐观锁的比较

悲观锁会堵塞锁的线程,这种费用是固定的。悲观锁的原始费用高于乐观锁。虽然乐观锁的初始费用比悲观锁小,但如果一直拿不到锁或者并发量大,竞争激烈,会导致不断的重试,所以会消耗越来越多的资源,甚至超过悲观锁。

以上就是java悲观锁和乐观锁的比较,希望对大家有所帮助。更多Java学习指路:Java基础

关注公众号

关注公众号,随时随地在线学习

本教程部分素材来源于网络,版权问题联系站长!

底部广告图 底部广告图按钮