java併發程式設計JUC第十一篇:如何線上程之間進行對等資料交換
java.util.concurrent.Exchanger
可以用來進行資料交換,或者被稱為“資料交換器”。兩個執行緒可以使用Exchanger交換資料,下圖用來說明Exchanger的作用
在下面的程式碼中
- 首先我們定義了一個Exchanger,用於資料交換
- 然後定義了兩個執行緒物件bookExchanger1和bookExchanger2,兩個執行緒都持有Exchanger交換器物件用於資料交換
- 兩個執行緒中的每個執行緒都有自己的資料,比如下面程式碼中的String[] 書籍陣列。
public static void main(String[] args) {
//資料交換器-資料為book
Exchanger<String> exchanger = new Exchanger<>();
//換書執行緒1
BookExchanger bookExchanger1
= new BookExchanger(exchanger, new String[]{"Java從入門到放棄","Java程式設計思想"});
//換書執行緒2
BookExchanger bookExchanger2
= new BookExchanger(exchanger, new String[]{"C語言程式設計","實戰Python資料分析"});
new Thread(bookExchanger1).start();
new Thread(bookExchanger2).start();
}
BookExchanger 繼承自Runnable代表參與換書的換書讀者,他持有Exchanger資料交換器用於交換圖書。
public class BookExchanger implements Runnable{
Exchanger<String> exchanger = null; //資料交換器
String[] books = null; //圖書陣列
public BookExchanger(Exchanger<String> exchanger, String[] books) {
this.exchanger = exchanger;
this.books = books;
}
[@Override](https://my.oschina.net/u/1162528)
public void run() {
try {
for(String bookName : books) {
//交換資料,bookName為我的書,exBook為我換回來的書
String exBook = this.exchanger.exchange(bookName);
System.out.println(
Thread.currentThread().getName() +
" 用《 " + bookName + "》 換 《 " + exBook + "》"
);
}
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
執行上文中的程式碼,得到如下的列印輸出。可以看到只有兩個執行緒完成一次交換之後,才能再進行下一次的交換。
Thread-1 用《 C語言程式設計》 換 《 Java從入門到放棄》
Thread-0 用《 Java從入門到放棄》 換 《 C語言程式設計》
Thread-1 用《 實戰Python資料分析》 換 《 Java程式設計思想》
Thread-0 用《 Java程式設計思想》 換 《 實戰Python資料分析》
歡迎關注我的部落格,裡面有很多精品合集
本文轉載註明出處(必須帶連線,不能只轉文字):字母哥部落格 - zimug.com
覺得對您有幫助的話,幫我點贊、分享!您的支援是我不竭的創作動力! 。另外,筆者最近一段時間輸出瞭如下的精品內容,期待您的關注。
「其他文章」
- 長篇圖解java反射機制及其應用場景
- 併發程式設計系列之Lock鎖可重入性與公平性
- java併發程式設計JUC第十二篇:AtomicInteger原子整型
- java併發程式設計JUC第十一篇:如何線上程之間進行對等資料交換
- java併發程式設計JUC第十篇:CyclicBarrier執行緒同步
- java併發程式設計JUC第九篇:CountDownLatch執行緒同步
- java併發程式設計JUC第八篇:ConcurrentHashMap
- java併發程式設計工具類JUC第七篇:BlockingDeque雙端阻塞佇列
- java併發程式設計工具類JUC第六篇:SynchronousQueue同步佇列
- java併發程式設計工具類JUC第五篇:PriorityBlockingQueue優先順序佇列
- java併發程式設計工具類JUC第四篇:LinkedBlockingQueue連結串列佇列
- java併發程式設計工具類JUC第三篇:DelayQueue延時佇列
- java併發程式設計工具類JUC第二篇:ArrayBlockingQueue
- java併發程式設計工具類JUC第一篇:BlockingQueue阻塞佇列
- 快速入門Redis呼叫Lua指令碼及使用場景介紹
- Mybatis plus通用欄位自動填充的最佳實踐總結
- 詳解執行緒池的作用及Java中如何使用執行緒池
- Java9系列第九篇-對HTTP2協議的支援與非阻塞HTTP-API
- 跨站資源共享CORS原理深度解析
- 你以前看的執行緒狀態轉換圖可能都是錯的-圖解併發程式設計第二篇