乐观锁和悲观锁的区别和使用场合

一:乐观锁(Optimistic Lock)

 每次获取数据的时候,都不会担心数据会被修改,所以每次获取数据时都不会进行加锁。

 但是在更新数据的时候,需要判断该数据是否被别人修改过,如果数据被其他线程修改过,则不进行数据更新。

 如果数据没有被其他线程修改,则进行数据更新。由于数据没有进行加锁,期间该数据可以被其他线程进行读写操作。

二:悲观锁(Pessimistic Lock)

 每次获取数据的时候,都会担心数据会被修改,所以每次获取数据的时候都会进行加锁,

 确保在自己使用的过程中数据不被别人修改,使用完后进行数据解锁。

 由于数据会进行加锁,期间对该数据进行读写和其他线程都会进行等待。

三:适用场合

  乐观锁:比较适合读取操作比较频繁的场合。

      如果出现大量的写入操作,数据发生冲突的可能性就会增大,为了保证数据的一致性,

      应用层需要不断的重新获取数据,这样会增加大量的查询操作,降低了系统的吞吐量。

  悲观锁:比较适合写入操作比较频繁的场合。

      如果出现大量的读取操作,每次读取的时候都会进行加锁,这样会增加大量的锁的开销,降低了系统的吞吐量。

  总结:两种锁各有各的优点,读取频繁使用乐观锁,写入频繁使用悲观锁。

  

  

  

猜你喜欢

转载自www.cnblogs.com/fanhaiping/p/9577486.html
今日推荐