乐观锁和悲观锁(不看后悔,看了必懂)

版权声明:本文为博主原创文章,未经博主允许可以转载。 https://blog.csdn.net/qq_36071795/article/details/83818267

锁从宏观上分类,分为乐观锁和悲观锁

乐观锁是一种乐观的思想,每次获取数据的时候都不担心数据会被修改,所以每次获取数据的时候都不会加锁,但是在更新的时候需要判断该数据是否被人修改过.如果数据被其他线程修改,则不进行数据更新,否则,更新.由于数据没有加锁,期间该数据可以被其他线程进行读写操作

在数据库中,乐观锁主要通过数据版本记录机制实现,即为数据增加一个版本号,读取数据时将此版本号一同读出,更新时对此版本号加1,如果提交数据的版本号大于数据库当前的版本号则予以更新,否则认为是过期数据

Java中的乐观锁大多使用CAS操作实现,CAS是一种更新的原子操作,比较当前值和传入的值是否一样,一样则更新,否则,不更新.

Java中的自旋锁,轻量级锁和偏向锁都属于乐观锁

悲观锁是一种悲观的思想,每次获取数据的时候都会担心数据被修改,所以每次获取数据的时候都会进行加锁,确保自己在使用的过程中数据不会被别人修改,使用完成后释放锁.由于数据进行加锁,期间对该数据的读写操作都会等待

Java中的悲观锁就是synchronized(重量级锁,非公平锁),AQS下的锁是先尝试CAS下的乐观锁去获取锁,如果获取不到,才会转换为悲观锁,如ReenTrantLock

 

总结:读取频繁使用乐观锁,写入频繁使用悲观锁

猜你喜欢

转载自blog.csdn.net/qq_36071795/article/details/83818267
今日推荐