悲观锁:就是每次有对象调用数据时,都会认为数据可能会被修改,所以会把对象锁起来,直到拿到锁之后才能调用,所以说会引起阻塞。常见的synchronized与ReentrantLock等独占锁都是基于悲观锁的。
乐观锁:每次有对象调用数据的时候,都认为不会对数据进行修改,所以锁是打开状态的,但是会在更新的时候判断数据是否被修改。可以使用版本号机制和CAS算法来实现。
因为悲观锁会造成阻塞,所以会造成资源的浪费,尤其是在调用数据对象多的时候。乐观锁的话适用于读的情况比较多的对象,能够提高系统吞吐量,从而提高效率。