缓存设计--读写锁场景实现
生活随笔
收集整理的這篇文章主要介紹了
缓存设计--读写锁场景实现
小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
/*** 設(shè)計(jì)一個(gè)緩存系統(tǒng)* 讀寫鎖的應(yīng)用。* JDK1.5自帶的讀寫鎖特性,讀與讀不互斥,讀與寫互斥,寫與寫互斥。* 為什么要使用讀寫鎖?一句話概括那就是提高系統(tǒng)性能,如何提高呢?* 試想,對(duì)于所有對(duì)讀的操作是不需要線程互斥的,而如果方法內(nèi)* 使用了synchronized關(guān)鍵字同步以達(dá)到線程安全,對(duì)于所有的線程不管是讀還是寫的操作都要同步。* 這時(shí)如果有大量的讀操作時(shí)就會(huì)又性能瓶頸。** 所以,當(dāng)一個(gè)方法內(nèi)有多個(gè)線程訪問(wèn),并且方法內(nèi)有讀和寫讀操作時(shí),* 提升性能最好的線程安全辦法時(shí)采用讀寫鎖的機(jī)制對(duì)讀寫互斥、寫寫互斥。這樣對(duì)于讀讀就沒(méi)有性能問(wèn)題了**/public void readWriteMathod(String key){readWriteLock.readLock().lock();//讀鎖,只對(duì)寫的線程互斥Object value = null;try {// 嘗試從緩存中獲取數(shù)據(jù)value = map.get(key);if (value == null) {readWriteLock.readLock().unlock();//發(fā)現(xiàn)目標(biāo)值為null,釋放掉讀鎖readWriteLock.writeLock().lock();//發(fā)現(xiàn)目標(biāo)值為null,需要取值操作,上寫鎖try {value = map.get(key);// 很嚴(yán)謹(jǐn)這一步。再次取目標(biāo)值if (value == null) {//很嚴(yán)謹(jǐn)這一步。再次判斷目標(biāo)值,防止寫鎖釋放后,后面獲得寫鎖的線程再次進(jìn)行取值操作// 模擬DB操作value = new Random().nextInt(10000) + "test";map.put(key, value);System.out.println("db completed!");}readWriteLock.readLock().lock();//再次對(duì)讀進(jìn)行鎖住,以防止寫的操作,造成數(shù)據(jù)錯(cuò)亂} finally {/** 先加讀鎖再釋放寫鎖讀作用:* 防止在100行出多個(gè)線程獲得寫鎖進(jìn)行寫的操作,所以在寫鎖還沒(méi)有釋放前要上讀鎖*/readWriteLock.writeLock().unlock();}}} finally {readWriteLock.readLock().unlock();}}
轉(zhuǎn)載于:https://www.cnblogs.com/kaleidoscope/p/9877743.html
總結(jié)
以上是生活随笔為你收集整理的缓存设计--读写锁场景实现的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: centos 7 Chrony 集群同步
- 下一篇: Gym 101964 2018-2019