欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java高并發(fā)中的交換器Exchanger解析

 更新時間:2023年12月02日 10:07:34   作者:safe_u  
這篇文章主要介紹了Java高并發(fā)中的交換器Exchanger解析,如果兩個線程并行處理,但在某個時刻需要互相交換自己已經處理完的中間數(shù)據(jù),然后才能繼續(xù)往下執(zhí)行,這個時候就可以使用 Exchanger,需要的朋友可以參考下

1.Exchanger簡介

Exchanger — 交換器,是JDK1.5時引入的一個同步器,從字面上就可以看出,這個類的主要作用是交換數(shù)據(jù)。

如果兩個線程并行處理,但在某個時刻需要互相交換自己已經處理完的中間數(shù)據(jù),然后才能繼續(xù)往下執(zhí)行。這個時候就可以使用 Exchanger。

Thread1線程到達柵欄后,會首先觀察有沒其它線程已經到達柵欄,如果沒有就會等待,如果已經有其它線程(Thread2)已經到達了,就會以成對的方式交換各自攜帶的信息,因此Exchanger非常適合用于兩個線程之間的數(shù)據(jù)交換。

2.Exchanger的使用

2.1 常用方法

//實現(xiàn)數(shù)據(jù)交換,x是交換的數(shù)據(jù),V是返回對方線程傳遞的數(shù)據(jù)
public V exchange(V x) throws InterruptedException
?
//用于交換,啟動交換并等待另一個線程調用exchange,并且設置最大等待時間,當?shù)却龝r間超過timeout便停止等待。
public V exchange(V x, long timeout, TimeUnit unit)

2.2 使用舉例

//數(shù)據(jù)交換器,用于數(shù)據(jù)交換
        Exchanger<String> exchanger = new Exchanger<>();
?
        //換書線程1
        new Thread(()->{
            String[] books_A = new String[]{"C++","操作系統(tǒng)"};//圖書數(shù)組
            for (String bookNameA:books_A) {
                try {
                    //交換數(shù)據(jù),bookNameA為我的書,exBook_A為我換回來的書
                    //System.out.println("線程A準備提交《"+bookNameA+"》書籍,等待交換...");
                    String exBook_A = exchanger.exchange(bookNameA);
                    System.out.println(Thread.currentThread().getName()+" 用 《"+bookNameA+"》換《"+exBook_A+"》");
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
            }
?
        },"線程A").start();
?
        //換書線程2
        new Thread(()->{
            String[] books_B = new String[]{"Java攻略","并發(fā)編程"};//圖書數(shù)組
            for (String bookNameB:books_B) {
                try {
                    String exBook_B = exchanger.exchange(bookNameB);
                    System.out.println(Thread.currentThread().getName()+" 用 《"+bookNameB+"》換《"+exBook_B+"》");
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
            }
        },"線程B").start();
  • Exchanger 支持多個線程做數(shù)據(jù)交換;
  • 多個線程使用同一個 Exchanger 做數(shù)據(jù)交換時,結果隨機,只要湊滿一對,就會進行交換。

到此這篇關于Java高并發(fā)中的交換器Exchanger解析的文章就介紹到這了,更多相關Java的Exchanger內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • Java中的繼承與接口解讀

    Java中的繼承與接口解讀

    這篇文章主要介紹了Java中的繼承與接口使用,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-02-02
  • java中Properties文件加載和使用方法

    java中Properties文件加載和使用方法

    這篇文章主要為大家詳細介紹了java中Properties文件加載和使用方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-03-03
  • Java使用動態(tài)規(guī)劃算法思想解決背包問題

    Java使用動態(tài)規(guī)劃算法思想解決背包問題

    背包問題(Knapsack problem)是一種組合優(yōu)化的NP完全問題。問題可以描述為:給定一組物品,每種物品都有自己的重量和價格,在限定的總重量內,我們如何選擇,才能使得物品的總價格最高
    2022-04-04
  • 基于Java實現(xiàn)楊輝三角 LeetCode Pascal''s Triangle

    基于Java實現(xiàn)楊輝三角 LeetCode Pascal''s Triangle

    這篇文章主要介紹了基于Java實現(xiàn)楊輝三角 LeetCode Pascal's Triangle的相關資料,需要的朋友可以參考下
    2016-01-01
  • Java編程中使用XFire框架調用WebService程序接口

    Java編程中使用XFire框架調用WebService程序接口

    這篇文章主要介紹了Java編程中使用XFire調用WebService程序接口的方法,WebService是一種跨編程語言和跨操作系統(tǒng)平臺的遠程調用技術,需要的朋友可以參考下
    2015-12-12
  • Servlet3.0實現(xiàn)文件上傳的方法

    Servlet3.0實現(xiàn)文件上傳的方法

    本篇文章主要介紹了Servlet實現(xiàn)文件上傳的方法,所謂文件上傳就是將本地的文件發(fā)送到服務器中保存。有興趣的可以了解一下。
    2017-03-03
  • 簡單了解Spring Web相關模塊運行原理

    簡單了解Spring Web相關模塊運行原理

    這篇文章主要介紹了簡單了解Spring Web相關模塊運行原理,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-06-06
  • Java詳細分析講解泛型

    Java詳細分析講解泛型

    在正式進入內容之前說明一下:泛型的內容太多,也太復雜。這里因為Java中寫數(shù)據(jù)結構的時候會使用到,所以加上。關于泛型我找了挺多文章,再結合自己的理解,盡可能將其講清楚。不求會使用泛型,只要求后面數(shù)據(jù)結構出現(xiàn)泛型的時候能夠知道是在干什么即可
    2022-05-05
  • java使用Hashtable過濾數(shù)組中重復值的方法

    java使用Hashtable過濾數(shù)組中重復值的方法

    這篇文章主要介紹了java使用Hashtable過濾數(shù)組中重復值的方法,涉及java數(shù)組遍歷及過濾的相關技巧,需要的朋友可以參考下
    2016-08-08
  • RocketMQ生產消息與消費消息超詳細講解

    RocketMQ生產消息與消費消息超詳細講解

    這篇文章主要介紹了RocketMQ生產消息與消費消息,RocketMQ可用于以三種方式發(fā)送消息:可靠的同步、可靠的異步和單向傳輸。前兩種消息類型是可靠的,因為無論它們是否成功發(fā)送都有響應
    2022-12-12

最新評論