java线程同步
来源:互联网 发布:数据库导入excel 编辑:程序博客网 时间:2024/06/05 20:55
(a).重入方面其内部的WriteLock可以获取ReadLock,但是反过来ReadLock想要获得WriteLock则永远都不要想。(b).WriteLock可以降级为ReadLock,顺序是:先获得WriteLock再获得ReadLock,然后释放WriteLock,这时候线程将保持Readlock的持 有。反过来ReadLock想要升级为WriteLock则不可能,为什么?参看(a),呵呵.(c).ReadLock可以被多个线程持有并且在作用时排斥任何的WriteLock,而WriteLock则是完全的互斥。这一特性最为重要,因为对于高 读取频率而相对较低写入的数据结构,使用此类锁同步机制则可以提高并发量。(d).不管是ReadLock还是WriteLock都支持Interrupt,语义与ReentrantLock一致。(e).WriteLock支持Condition并且与ReentrantLock语义一致,而ReadLock则不能使用Condition,否则抛出 UnsupportedOperationException异常。
class CachedData{ ReentrantReadWriterLock有锁降级机制,写锁是exclusive锁,读锁是share锁,如果一个线程拿到了写锁,那么它还可以继续拿到读锁Object data;volatile boolean cacheValid;ReentrantReadWriteLock rwl = new ReentrantReadWriteLock();void processCachedData() {rwl.readLock().lock();if (!cacheValid) {// Must release read lock before acquiring write lockrwl.readLock().unlock();rwl.writeLock().lock();// Recheck state because another thread might have acquired// write lock and changed state before we did.if (!cacheValid) { data = ... cacheValid = true;}// Downgrade by acquiring read lock before releasing write lockrwl.readLock().lock();rwl.writeLock().unlock(); // Unlock write, still hold read}use(data);rwl.readLock().unlock();}}
这个降级的机制可能保证缓存中get操作的场景的原子性。
举例子。我想get操作的时候,发现数据已经失效,需要用新数据覆盖失效数据,并返回最新结果。这个场景用锁降级可以保证。当然用synchronized可以实现,只是那样的话就用不到读写锁的读读不互斥的优点了(转入正题)。
用大师的这个加锁顺序:
rwl.writeLock().lock();
rwl.readLock().lock();
rwl.writeLock().unlock();
rwl.readLock().unlock();
看出来了没?如果一个线程拿到了写锁,即使更新缓存的动作做完了,再拿到读锁,准备返回数据。这样可以保证返回的数据是这次更新的数据。如果没有这个降级机制的话,在释放了读锁之后,可能会被另外一个线程抢到读锁,继续更新缓存,再返回的数据就不是第一次更新的数据了。
0 0
- JAVA线程-JAVA同步
- Java线程:线程的同步-同步方法
- Java线程:线程的同步-同步块
- Java线程:线程的同步-同步方法
- Java线程:线程的同步-同步块
- Java线程:线程的同步-同步方法
- Java线程:线程的同步-同步方法
- Java线程:线程的同步-同步块
- Java线程:线程的同步-同步方法
- Java线程:线程的同步-同步块
- Java线程:线程的同步-同步方法
- Java线程:线程的同步-同步块
- Java线程:线程的同步-同步方法
- Java线程:线程的同步-同步块
- Java线程:线程的同步-同步方法
- Java线程:线程的同步-同步块
- Java线程:线程的同步-同步方法
- Java线程:线程的同步-同步方法
- ip斜杠表示法
- Fractal
- Linux MySql 启用InnoDB
- I/O复用
- ubuntu下编译适合ndk的x264(arm和x86)
- java线程同步
- MySQL5日期类型DATETIME和TIMESTAMP相关问题详解
- fatal error LNK1123: 转换到 COFF 期间失败: 文件无效或损坏 终极解决方案
- UVA 437 The Tower of Babylon
- 刘鹏计算广告学1:广告的基本知识(一)
- iOS 远程推送(Push Notification)实现
- VC++学习心得(六)
- Foundation框架
- 灌水VS抽水