1. 定义区别
悲观锁:悲观地认为如果不严格同步线程调用,那么一定会产生异常。所以互斥锁将会将资源锁定,只供一个线程调用,而阻塞其他线程(每次去拿数据的时候会认为别的线程也会同时修改数据)。
乐观锁:操作数据时非常乐观,认为别的线程不会同时修改数据,所以不会上锁,但是在更新的时候会判断在此期间别的线程有没有更新过这个数据。
2. 应用场景
悲观锁:适用于写多读少的情况。
乐观锁:适用于写少读多的情况,可以减少操作冲突,省去竞争的开销,提高系统的吞吐量。
参考资料:
- 什么是乐观锁,什么是悲观锁?
- 面试官问我CAS、乐观锁、悲观锁,我反手就是骑脸输出