Java并发编程基础-----锁

博客介绍了几种常见的锁机制。悲观锁在SQL语句末尾加for update,乐观锁在where语句中加version条件且提交时才锁定。公平锁和非公平锁可通过ReentrantLock的参数设置,无公平需求建议用非公平锁。还介绍了独占锁、共享锁和自旋锁的特点。

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

1 悲观锁和乐观锁
悲观锁:在sql语句末尾加上 for update
乐观锁:在sql的where语句中添加version条件

update tablel set name=#{name),age=#{age),version=${version)+1 where id =#{id} and version=#{version}

乐观锁并不会使用数据库提供的锁机制, 一般在表中添加version 宇段或者使用业务
状态来实现。乐观锁直到提交时才锁定,所以不会产生任何死锁。

2 公平锁和非公平锁
公平锁 :antLock pairLock = new ReentrantLock(true);
非公平锁: ReentrantLock pairLock = new ReentrantLock(false);
在没有公平性需求的前提下尽量使用非公平锁,因为公平锁会带来性能开销。

3 独占锁和共享锁
独占锁:保证任何时候都只有一个线程能得到锁,ReentrantLock、synchronized都属于独占锁;
共享锁:允许多个线程同时进行读操作,如ReadWriteLock允许多个线程同时读操作。

4 自旋锁
当前线程在获取锁时,如果发现锁已经被其他线程占有,它不马上阻塞自己,在不放弃CPU 使用权的情况下,多次尝试获取, 默认次数是10 ,可以使用-XX :PreBlockSpinsh 参数设置该值),这种实现方式可能会浪费CPU的时间。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值