一、概念
悲观锁顾名思义:数据被外界修改总是保持悲观的态度,事物每次去操作数据的时候,都假设有其他事物要修改访问的数据,所以在访问数据之前,都要加上锁,因此数据在操作过程中,数据是被锁定的。进一步解释:总是假设在最坏的情况下,每次去拿数据的时候都认为会被别人修改,所以在拿数据的时候,对数据加锁,别人拿数据的时候就会阻塞,直到它获取该数据的锁,传统的关系型数据库都使用到这种锁,例如:行锁,表锁,读锁和写锁,都是在操作之前先加上锁,java里面的同步synchronized关键字的实现也是悲观锁;
乐观锁:数据被外界修改总是保持乐观的态度,即事物每次去操作数据之前,都不会有其他事物修改数据,所以在访问之前,不会加锁,但是在更新的时候,会判断数据是否被修改,说的直白一点就是:总是假设在最好的情况下,每次去拿数据的时候不会被被人修改,因此也不会加锁,但是在更新的时候,会判断一下,在这个期间,数据是否被修改,可以使用版本号机制和cas算法实现