乐观锁:
乐观锁在操作数据时非常乐观,认为别人不会同时修改数据。
. 因此乐观锁不会上锁,只是在执行更新的时候判断一下在此期间别人
是否修改了数据:如果别人修改了数据则放弃操作,否则执行操作。.
乐观锁是一种并发类型的锁,其本身不对数据进行加锁通而是通过业务
实现锁的功能,不对数据进行加锁就意味着允许多个请求同时访问数据,
同时也省掉了对数据加锁和解锁的过程,这种方式因为节省了悲观锁加
锁的操作,所以可以一定程度的的提高操作的性能,不过在并发非常高
的情况下,会导致大量的请求冲突,冲突导致大部分操作无功而返而浪
费资源,所以在高并发的场景下,乐观锁的性能却反而不如悲观锁。
悲观锁:
悲观锁在操作数据时比较悲观,认为别人会同时修改数据。.
因此操作数据时直接把数据锁住,直到操作完成后才会释放锁;上锁
期间其他人不能修改数据。可以完全保证数据的独占性和正确性,因为
每次请求都会先对数据进行加锁, 然后进行数据操作,最后再解锁,
而加锁释放锁的过程会造成消耗,所以性能不高;
乐观锁和悲观锁优缺点和适用场景
乐观锁和悲观锁并没有优劣之分,它们有各自适合的场景
当竞争不激烈 (出现并发冲突的概率小)时,乐观锁更有优势
,因为悲观锁会锁住代码块或数据,其他线程无法同时访问
,影响并发,而且加锁和释放锁都需要消耗额外的资源。
当竞争激烈(出现并发冲突的概率大)时,悲观锁更有优势,因
为乐观锁在执行更新时频繁失败,需要不断重试,浪费CPU资源。