Java的通過管道來實現執行緒通訊
前言與一點思考
最近使用golang的channel併發程式設計非常爽,又快又方便還不用考慮什麼執行緒不安全的問題,同時在想老相好Java的channel類似實現有沒有呢?
Java四種通訊方式,分別是synchronized關鍵字,while(true)輪詢,wait和notify以及java.io.Pipe,實際上這個java.io.Pipe和go的channel邏輯是相似的。
Java管道的認識
PipedWriter(允許任務向管道寫),和PipedReader(允許不同任務從同一管道中讀取)。管道也可以理解為一個緩衝區,將要讀寫的內容存入到管道,輸入輸出都要從這個管道去操作,管道提供了一個封裝好的解決方案。
程式碼
package cn.com.controller;
import java.io.IOException;
import java.io.PipedReader;
import java.io.PipedWriter;
import java.util.Random;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.ThreadPoolExecutor;
import java.util.concurrent.TimeUnit;
/**
* @author wangjie
* @version 2018/11/21
* 任務間使用管道進行輸入輸出
*/
class Sender implements Runnable{
private Random random = new Random(47);
private PipedWriter out = new PipedWriter();
public PipedWriter getPipedWriter(){ return out; }
@Override
public void run(){
try{
for(int i=0;i<20;i++){
out.write(i);
//隨機休眠500以內毫秒
TimeUnit.MILLISECONDS.sleep(random.nextInt(500));
}
}catch(IOException e){
System.out.println(e + " Sender write exception");
}catch(InterruptedException e){
System.out.println(e + " Sender sleep interrupt");
}
}
}
class Receiver implements Runnable{
private PipedReader in;
public Receiver(Sender sender) throws IOException{
in = new PipedReader(sender.getPipedWriter());
}
@Override
public void run(){
try{
System.out.println("Read: " + (int)in.read() + ",");
}catch(IOException e){
System.out.println(e + " Receiver read exception");
}
}
}
public class TestPieIo {
public static void main(String[] args) throws Exception{
Sender sender = new Sender();
Receiver receiver = new Receiver(sender);
ExecutorService exec = Executors.newFixedThreadPool(4);
exec.execute(sender);
for (int i=0;i<10;i++) {
exec.execute(receiver);
}
//休眠40秒鐘後中斷
TimeUnit.SECONDS.sleep(40);
exec.shutdownNow();
}
}
輸出:
Read: 0,
Read: 1,
Read: 2,
Read: 3,
Read: 4,
Read: 5,
Read: 6,
Read: 7,
Read: 8,
Read: 9,
並一直阻塞,因為只有十個讀者在讀,只能消費管道的十個資料,所以程式會一直阻塞。
相關文章
- Java執行緒通訊Java執行緒
- Java多執行緒-執行緒通訊Java執行緒
- Java之執行緒通訊Java執行緒
- java多執行緒5:執行緒間的通訊Java執行緒
- java多執行緒間的通訊Java執行緒
- Java多執行緒學習——執行緒通訊Java執行緒
- 匿名管道通訊實現
- Java中的執行緒通訊詳解Java執行緒
- 說說Java執行緒間通訊Java執行緒
- Java執行緒(九):Condition-執行緒通訊更高效的方式Java執行緒
- Java多執行緒學習(3)執行緒同步與執行緒通訊Java執行緒
- libuv執行緒通訊執行緒
- JAVA - 基於Socket的多執行緒通訊Java執行緒
- Java-執行緒間通訊小結Java執行緒
- 【Java】【多執行緒】兩個執行緒間的通訊、wait、notify、notifyAllJava執行緒AI
- Android中的執行緒通訊Android執行緒
- Java多執行緒中的wait/notify通訊模式Java執行緒AI模式
- Java併發程式設計之執行緒安全、執行緒通訊Java程式設計執行緒
- EventBus,輕鬆實現跨元件跨執行緒通訊元件執行緒
- Android執行緒間通訊Android執行緒
- Java 執行緒間通訊 —— 等待 / 通知機制Java執行緒
- 子執行緒與UI執行緒的通訊(委託)執行緒UI
- 多執行緒之間的通訊執行緒
- JUC之執行緒間的通訊執行緒
- 多執行緒通訊軟體——登入介面的實現執行緒
- java多執行緒實現TCP網路Socket程式設計(C/S通訊)Java執行緒TCP程式設計
- JUC執行緒高階---執行緒控制通訊Condition執行緒
- 多執行緒之間通訊及執行緒池執行緒
- 深入理解執行緒通訊執行緒
- Java之執行緒安全問題的3種處理方式(通過執行緒同步)Java執行緒
- java socket 通訊socketServer 服務端多執行緒JavaServer服務端執行緒
- 一個SystemC執行緒與SystemVerilog執行緒通訊的例子執行緒
- Android小知識-Java多執行緒相關(執行緒間通訊)上篇AndroidJava執行緒
- java多執行緒:執行緒間通訊——生產者消費者模型Java執行緒模型
- 多執行緒Demo學習(執行緒的同步,簡單的執行緒通訊)執行緒
- 通過原始碼理解 Java 執行緒池的核心引數原始碼Java執行緒
- Java多執行緒技術:實現多使用者服務端Socket通訊Java執行緒服務端
- iOS GCD執行緒之間的通訊iOSGC執行緒