java 同步器SynchronousQueue詳解及實例
同步器簡介
學(xué)習(xí)以來對線程的操作有很大的改觀,從c/c++的mutex到j(luò)ava的各種鎖(當(dāng)然不是嫌麻煩,java讀寫鎖的實現(xiàn)還是帶來不少好處的,但是sokcet的設(shè)計我就不敢恭維了,tcp和udp是兩個類,弄得我現(xiàn)在對udp也不怎么熟悉)。其中最讓我感到特別剛需的設(shè)計就是同步器,除了countdownlatch,剩下的都比較剛需,cyclicbarrier我現(xiàn)在唯一能感覺他的好用處就是循環(huán)打印a,b,exchanger和SynchronousQueue我一直沒發(fā)現(xiàn)什么作用,兩個就適合生產(chǎn)者消費者問題。以上就是四大同步器,聽說過2個以上的就很厲害了,有些場合太難想了。
場景思路
這次說最后兩個用的場景吧,我要做的事情呢,是采集一堆數(shù)據(jù),然后采集另外的數(shù)據(jù)綜合處理,但是兩個數(shù)據(jù)是和時間相關(guān)的,如果順序執(zhí)行的話,那么處理結(jié)果的可信度越低,最初的設(shè)想就是利用異步處理,兩個數(shù)據(jù)采集同時進行,然后一起處理,futuretask,就作為首選,我的采集信息還是周期性的任務(wù),必需要用定時的線程池了,但是這種線程池(別說timer,這個類更建議用線程池替換)并沒有為異步處理做返回值,我也沒辦法直接獲取處理的數(shù)據(jù)了,無奈的情況下只能用線程來做了,同時也必須要用同步器來同步了,用手動阻塞線程然后喚醒這個行為實在是太不可取了,你全喚醒了,可能造成不該運行的代碼開始運行,喚醒單個,還得看cpu的調(diào)度,于是想到了exchanger和SynchronousQueue,我最終選取了SynchronousQueue。
SynchronousQueue
其實就是特殊的阻塞隊列,特殊就特殊在他最多放一個元素,而且這個元素不在特定的時間消費掉就沒了,而且永遠(yuǎn)長度都是0,具體看api就發(fā)現(xiàn)能用的方法沒幾個,3個是放入,2個是取走。
demo
生產(chǎn)者,消息最多存放1分鐘
public void run() { try { queue.offer(i++,1,TimeUnit.MINUTES); } catch (InterruptedException e) { e.printStackTrace(); } System.out.println("add"); }
消費者
System.out.println(queue.poll(1,TimeUnit.SECONDS));
用了這個同步器,這種定時生產(chǎn)者消費者問題,代碼量就很少,不需要自己再寫同步的代碼了。也避免了最初喚醒阻塞帶來的不可預(yù)估性。
感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
相關(guān)文章
SpringMVC 數(shù)據(jù)校驗方法(必看篇)
下面小編就為大家?guī)硪黄猄pringMVC 數(shù)據(jù)校驗方法(必看篇)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-06-06Java?Stream比較兩個List的差異并取出不同的對象四種方法
今天開發(fā)一個需求時要對A和B兩個List集合遍歷,并比較出集合A有,而集合B沒有的值,下面這篇文章主要給大家介紹了關(guān)于Java?Stream比較兩個List的差異并取出不同對象的四種方法,需要的朋友可以參考下2024-01-01Spring Data JPA使用Sort進行排序(Using Sort)
本篇文章主要介紹了Spring Data JPA使用Sort進行排序(Using Sort),具有一定的參考價值,有興趣的可以了解一下2017-07-07java calendar 日期實現(xiàn)不斷加一天的代碼
這篇文章主要介紹了java calendar 日期實現(xiàn)不斷加一天的代碼,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-10-10mybatis注解之@Mapper和@MapperScan的使用
這篇文章主要介紹了mybatis注解之@Mapper和@MapperScan的使用,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-10-10