StampedLock 使用注意事项
- StampedLock 的功能是 ReadWriteLock 的子集
- StampedLock 在命名上并没有增加 Reentrant,他是不可重入的。
- StampedLock 的悲观读锁、写锁都不支持条件变量(支持条件变量意味着等待阻塞,与实现多线程读矛盾)
- 如果线程阻塞在 StampedLock 的 readLock() 或者 writeLock() 上时,此时调用该阻塞线程的 interrupt() 方法,会导致 CPU 飙升。
- 案例:例如下面的代码中,线程 T1 获取写锁之后将自己阻塞,线程 T2 尝试获取悲观读锁,也会阻塞;如果此时调用线程 T2 的 interrupt() 方法来中断线程 T2 的话,你会发现线程 T2 所在 CPU 会飙升到 100%。
补充:
使用 StampedLock 一定不要调用中断操作,如果需要支持中断功能,一定使用可中断的悲观读锁 readLockInterruptibly() 和写锁 writeLockInterruptibly()。
StampedLock 支持锁的降级(通过 tryConvertToReadLock() 方法实现)和升级(通过 tryConvertToWriteLock() 方法实现),但是建议你要慎重使用。下方代码存在BUG
- 在锁升级成功的时候,最后没有释放最新的写锁,可以在if块的break上加个stamp=ws进行释放
StampedLock 读模板:先乐观读读取,然后校验读取过程中,数值是否发生了变化,如果发生了变化,则加入悲观锁,再重新读取。
StampedLock 写模板