乐观锁及其实现原理
乐观锁总是认为不会产生并发问题,每次去取数据的时候总认为不会有其他线程对数据进行修改,因此不会上锁,但是在更新时会判断其他线程在这之前有没有对数据进行修改,一般会使用版本机号或CAS操作实现。
version方式:一般是在数据表中加上一个数据版本号version字段,表示数据被修改的次数,当数据被修改时,version值会加一。当线程A要更新数据时,version值会加一。在提交更新时若刚才读到的version值为当前数据库中的version值相等时才更新,否则重试更新操作直到成功。
CAS操作方式:即compare and swap 或compare and set ,涉及到三个操作数,数据所在的内存值,新值。当需要更新时,判断当前内存值与之前取到的值是否相等。若相等则将新值写回,若不相等则重试,一般情况下是一个自旋操作,即不断的重试。
synchronized和ReentrantLock的区别
两者都是同步阻塞锁
功能区别: 1.Synchronized原生语法层面的互斥 JVM。
ReentTrantLock(1.5后 API 层互斥锁)。
2.便利性:Synchronized 方便简洁,由编译器去保证锁的加锁和释放。
ReentrantLock :手工声明未加锁和释放锁。
3.锁的细粒度和灵活度:ReenTrantLock > Synchronized
性能区别:
在Synchronized 优化前 性能 < ReentrantLock
高级功能:1.等待可中断, Lock.lockInterruptlbly();
2.公平锁 3.锁绑定多个条件。