Java LinkedBlockingQueue和ArrayBlockingQueue分析

來源:互聯網
上載者:User

標籤:style   blog   http   color   io   使用   ar   java   資料   

LinkedBlockingQueue是一個鏈表實現的阻塞隊列,在鏈表一頭加入元素,如果隊列滿,就會阻塞,另一頭取出元素,如果隊列為空白,就會阻塞。


LinkedBlockingQueue內部使用ReentrantLock實現插入鎖(putLock)和取出鎖(takeLock)。putLock上的條件變數是notFull,即可以用notFull喚醒阻塞在putLock上的線程。takeLock上的條件變數是notEmtpy,即可用notEmpty喚醒阻塞在takeLock上的線程。


知道了LinkedBlockingQueue,再來理解ArrayBlockingQueue就比較好理解了。類似LinkList和ArrayList的區別。如果知道隊列的大小,那麼使用ArrayBlockIngQueue就比較合適了,因為它使用迴圈數組實現,但是如果不知道隊列未來的大小,那麼使用ArrayBlockingQueue就必然會導致數組的來回複製,降低效率。


記住多線程保護的一定是資料,而不是代碼,在此例中,鎖保護的也是其中共用的隊列對象,防止出現不一致的情況。

原文:http://blog.csdn.net/hongchangfirst/article/details/39667677

作者:hongchangfirst

hongchangfirst的首頁:http://blog.csdn.net/hongchangfirst


Java LinkedBlockingQueue和ArrayBlockingQueue分析

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.