乐观锁,悲观锁,公平锁,非公平锁,死锁,可重入锁,同步锁,读写锁,表锁,行锁,间隙锁,排它锁,自旋锁

synchronized:悲观锁,递归锁,可重入锁(隐式),同步锁,非公平锁

ReentrantLock:悲观锁,递归锁,可重入锁(显式),同步锁,公平锁,非公平锁

悲观锁:线程阻塞,效率低

乐观锁:java.util.concurrent.atomic.*下面的类,保证了原子性,不需要加锁,效率高,或者版本号+1

公平锁:new ReentrantLock(true),多个人干活,效率低

非公平锁:new ReentrantLock(false)或者不传参数,一个人吧活都干了,其他人都闲着,效率高

可重入锁也叫递归锁

可重入锁:相当于大门的钥匙,可以随便访问其他的房间

死锁:两个线程都在等对方释放锁,线程一直等待,卡主不动了

读锁: 也叫共享锁,多个线程可以读取这条数据,但是不能修改这条数据

写锁: 也叫独占锁,排他锁,就是只能有一个线程来修改这条数据

表锁:当索引失效,行锁升级为表锁,或者where条件查询的是没有索引,修改数据的时候也会锁全表

行锁: 锁一条数据,匹配到索引,另一个窗口也在使用相同的数据会吧这一条数据锁住

间隙锁: 锁开始和结束条件,在这个范围内,如果在新增一条数据,那么会锁住

排它锁: 当一条sql加了这个for update,那么其他地方使用的时候,只能查询,不能修改

自旋锁: 简称cas,atomicReference.compareAndSet(key,value),比较atomic的数据和key是否一致,如果不一致,一直循环阻塞,如果一致,更新为value,跳过循环

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值