之前看到一个面试题说是讲一下悲观锁和乐观锁,网上搜到了一篇写的很明白的文章
文章用很通俗的语言描述了悲观锁和乐观锁的区别,下面根据自己的理解说一下
悲观锁:时刻保持着一个悲观的态度,对谁都不信任,总想着别人会修改我的数据,所以为了防止别人修改,每次都会上锁,防止别人修改自己的数据,导致的后果就是每次想要拿到数据就必须等待拿到锁,是一个很浪费时间的过程,如果访问量巨大,悲观锁的存在就是一个致命的缺陷。
乐观锁:相比于悲观锁,乐观锁对于这个世界都很乐观,对每个想要获取数据的操作,他都会认为大家都不会对自己的数据进行修改,所以不会上锁,在访问量巨大的时候相比于悲观锁,节省了很多的时间,用户不需要等待着获取锁。
悲观锁并不是一无是处,乐观锁也不是就是最好的,具体情况具体分析,在大量进行读取数据操作的时候,用乐观锁是做好的选择,但是在向数据库中写入数据的时候,如果冲突较多建议使用悲观锁,这样在数据库层面进行数据比较,不至于在业务代码之间来回检查。
下面说一下在什么情况下选择悲观锁和乐观锁:
如果追求响应速度,建议采用乐观锁,因为乐观锁不需要等待释放锁和获取锁。如果在一个数据冲突非常多的情况下,建议采用悲观锁,因为悲观锁保证了数据执行的成功率,乐观锁认为没有冲突,总会在尝试,很多的时间都是浪费在了来回的尝试。