Java編程線程同步工具Exchanger的使用執行個體解析,javaexchanger

來源:互聯網
上載者:User

Java編程線程同步工具Exchanger的使用執行個體解析,javaexchanger

本文研究的主要是Java編程線程同步工具Exchanger的使用,下面看看具體內容。

  如果兩個線程在運行過程中需要交換彼此的資訊,比如一個資料或者使用的空間,就需要用到Exchanger這個類,Exchanger為線程交換資訊提供了非常方便的途徑,它可以作為兩個線程交換對象的同步點,只有當每個線程都在進入 exchange ()方法並給出對象時,才能接受其他線程返回時給出的對象。

  每次只能兩個線程交換資料,如果有多個線程,也只有兩個能交換資料。下面看個通俗的例子:一手交錢一首交貨!

public class ExchangerTest {public static void main(String[] args) {ExecutorService service = Executors.newCachedThreadPool();final Exchanger exchanger = new Exchanger();//定義一個交換對象,用來交換資料//開啟一個線程執行任務service.execute(new Runnable(){@Override      public void run() {try {String data1 = "海洛因";System.out.println("線程" + Thread.currentThread().getName()               + "正在把毒品" + data1 + "拿出來");Thread.sleep((long)(Math.random()*10000));//把要交換的資料傳到exchange方法中,然後被阻塞,等待另一個線程與之交換。返回交換後的資料String data2 = (String)exchanger.exchange(data1);System.out.println("線程" + Thread.currentThread().getName() +           "用海洛因換來了" + data2);}catch(Exception e){}finally {service.shutdown();System.out.println("交易完畢,拿著錢快跑!");}}});//開啟另一個線程執行任務service.execute(new Runnable(){@Override      public void run() {try {String data1 = "300萬";System.out.println("線程" + Thread.currentThread().getName() +           "正在把" + data1 +"拿出來");Thread.sleep((long)(Math.random()*10000));String data2 = (String)exchanger.exchange(data1);System.out.println("線程" + Thread.currentThread().getName() +           "用300萬弄到了" + data2);}catch(Exception e){}finally {service.shutdown();System.out.println("交易完畢,拿著海洛因快跑!");}}});}}

從代碼中我彷彿看到了兩個人在交易毒品的場面……來看一下交易結果如何:

線程pool-1-thread-1正在把毒品海洛因拿出來
線程pool-1-thread-2正在把300萬拿出來
線程pool-1-thread-2用300萬弄到了海洛因
線程pool-1-thread-1用海洛因換來了300萬
交易完畢,拿著海洛因快跑!
交易完畢,拿著錢快跑!

 跑的倒是快,從運行結果來看,確實實現了資料的交換,這個只是交換一個基本類型的資料而已,它真正的用處不僅僅局限於此,比如我們可以交換一個對象,這就有用了,JDK官方提到了一個進階的應用:

使用 Exchanger 線上程間交換緩衝區,因此,在需要時,填充緩衝區的線程擷取一個新騰空的緩衝區,並將填滿的緩衝區傳遞給騰空緩衝區的線程。

  這就得根據實際情況了,思想和上面的一樣,實際中肯定要定義一個緩衝區的類,然後兩個線程之間交換的就是這個緩衝區的類即可,至於類中如何?,就得看實際情況了。Exchanger的使用就總結這麼多吧~

總結

以上就是本文關於Java編程線程同步工具Exchanger的使用執行個體解析的全部內容,希望對大家有所協助。感興趣的朋友可以繼續參閱本站其他相關專題,如有不足之處,歡迎留言指出。感謝朋友們對本站的支援!

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.