锁从宏观上分类,分为乐观锁和悲观锁
乐观锁是一种乐观的思想,每次获取数据的时候都不担心数据会被修改,所以每次获取数据的时候都不会加锁,但是在更新的时候需要判断该数据是否被人修改过.如果数据被其他线程修改,则不进行数据更新,否则,更新.由于数据没有加锁,期间该数据可以被其他线程进行读写操作
在数据库中,乐观锁主要通过数据版本记录机制实现,即为数据增加一个版本号,读取数据时将此版本号一同读出,更新时对此版本号加1,如果提交数据的版本号大于数据库当前的版本号则予以更新,否则认为是过期数据
Java中的乐观锁大多使用CAS操作实现,CAS是一种更新的原子操作,比较当前值和传入的值是否一样,一样则更新,否则,不更新.
Java中的自旋锁,轻量级锁和偏向锁都属于乐观锁
悲观锁是一种悲观的思想,每次获取数据的时候都会担心数据被修改,所以每次获取数据的时候都会进行加锁,确保自己在使用的过程中数据不会被别人修改,使用完成后释放锁.由于数据进行加锁,期间对该数据的读写操作都会等待
Java中的悲观锁就是synchronized(重量级锁,非公平锁),AQS下的锁是先尝试CAS下的乐观锁去获取锁,如果获取不到,才会转换为悲观锁,如ReenTrantLock
总结:读取频繁使用乐观锁,写入频繁使用悲观锁