StampedLock
当前线程获取读锁后,自身线程不能获取写锁,其他线程可以获取读锁不能获取写锁,尝试获取锁的线程会进入阻塞队列,直到读锁释放。
当前线程获取写锁后,自身线程可以获取读锁,其他线程不可以获取读锁和写锁。尝试获取锁的线程会阻塞,直到写锁释放。
使用StampedLock的原因?
采用乐观读,能进一步优化读性能。它的特点是在使用读锁、写锁时都必须配合印章使用
StampedLock的缺点:
不支持可重入;不支持条件变量
StampedLock的使用过程
在执行读操作之前先进行乐观读获取印章,这个方法内没有加锁,然后执行读取数据,执行完后进行校验印章
如果有其他线程执行了写操作加了写锁(读写规则和ReentrantReadWriteLock一样),会改变stamp的值,校验通不过就会重新加正常读锁重新执行读操作以读取最新值。
如果有其他线程执行了读操作加了乐观读锁,则不会改变stamp的值。
加解读锁
long stamp = lock.readLock();
lock.unlockRead(stamp);
加解写锁
long stamp = lock.writeLock();
lock.unlockWrite(stamp);
long stamp = lock.tryOptimisticRead();
//读操作
// 验戳
if(!lock.validate(stamp)){
// 锁升级为正常读锁
}