悲观锁:
每次获取到数据的时候,都会担心数据被修改,所以每次获取数据的时候都会进行加锁,确保在自己使用的过程中数据不会被别人修改,使用完成后进行数据解锁
期间对该数据进行读写的其他线程都会进行等待
乐观锁:
每次获取数据的时候,都不会担心数据被修改,所以每次获取数据的时候都不会进行加锁。
但是在更新数据的时候需要判断该数据是否被别人修改过。如果数据被其他线程修改,则不进行数据更新;如果没有被修改,则进行数据更新
期间该数据可以被其他线程进行读写操作
适用场景:
悲观锁:
适合写入操作比较频繁的场景
如果出现大量的读取操作,每次读取的时候都会进行加锁,会增加锁的开销,降低了性能
乐观锁:
适合读取操作比较频繁的场景
如果出现大量的写入操作,可能会出现数据冲突,不能保证数据一致性。而为了保证数据的一致性,上层应用需要不断重获数据,会大大增加查询操作,降低性能
总结:
悲观锁比较适合强一致性的场景,但效率比较低,特别是读的并发低
乐观锁则适用于读多写少,并发冲突少的场景