JUC StampedLock

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)){

// 锁升级为正常读锁

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值