乐观锁:
乐观锁认为自己在操作数据时,不会有其他的线程对数据进行更改,因此她不会对数据上锁,但是在他更新时会对数据进行判断,观察数据是否被改变,如果没有没有那么直接对数据进行更新,假如在这个期间数据被改变了,那么就一直重复这个过程直到成功。
乐观锁一般用version或者CAS操作来实现。
version:在数据表加一个数据版本号,乐观锁线程在操作数据是,会先读取版本号,在更新是会再次获得版本号,只有在两次的版本号是相同的时候才会进行更新操作,如果version号不同,那么就一直重复更新,直到成功为止。
CAS:Compare and Swap,意思是在Swap之前先进行Compare,只有数据的内存值没有改变才进行Swap操作,他是一个自旋操作,失败就不断重试。
悲观锁:
悲观锁认为自己在操作数据时,总会有其他线程进行并发修改,所以每次悲观锁线程进行操作时,会先对数据上锁,操作结束后再对锁进行释放。
悲观锁的典型应用:数据库中X锁S锁行锁,Java中的synchronized关键字都是典型的悲观锁思想