上一章節(jié)講了wait/notify通信,這一節(jié)我們來探討使用管道進(jìn)行通信。

創(chuàng)新互聯(lián)公司一直在為企業(yè)提供服務(wù),多年的磨煉,使我們在創(chuàng)意設(shè)計(jì),全網(wǎng)整合營銷推廣到技術(shù)研發(fā)擁有了開發(fā)經(jīng)驗(yàn)。我們擅長傾聽企業(yè)需求,挖掘用戶對產(chǎn)品需求服務(wù)價(jià)值,為企業(yè)制作有用的創(chuàng)意設(shè)計(jì)體驗(yàn)。核心團(tuán)隊(duì)擁有超過10年以上行業(yè)經(jīng)驗(yàn),涵蓋創(chuàng)意,策化,開發(fā)等專業(yè)領(lǐng)域,公司涉及領(lǐng)域有基礎(chǔ)互聯(lián)網(wǎng)服務(wù)光華機(jī)房服務(wù)器托管、重慶APP軟件開發(fā)、手機(jī)移動(dòng)建站、網(wǎng)頁設(shè)計(jì)、網(wǎng)絡(luò)整合營銷。
java中提供了IO流使我們很方便的對數(shù)據(jù)進(jìn)行操作,pipeStream是一種特殊的流,用于不同線程間直接傳送數(shù)據(jù)。一個(gè)線程將數(shù)據(jù)發(fā)送到輸出管道,另一個(gè)線程從輸入管道讀取數(shù)據(jù)。通過管道實(shí)現(xiàn)通信不需要借助臨時(shí)文件這類東西。
java中提供了四個(gè)類使得線程間可以通信:
①字節(jié)流:PipeInputStream,PipedOutputStream
②字符流:PipedReader,PipedWriter
下面我們看看字節(jié)流的實(shí)現(xiàn)方法:
package pipeInputOutput;
//輸出流
import java.io.IOException;
import java.io.PipedOutputStream;
public class WriteDate {
public void writeMethod(PipedOutputStream out) {
try {
System.out.println("write:");
for(int i=0;i<300;i++) {
String outDate=""+(i+1);
out.write(outDate.getBytes());
System.out.print(outDate);
}
System.out.println();
out.close();
}catch(IOException e) {
e.printStackTrace();
}
}
}
package pipeInputOutput;
//輸入流
import java.io.IOException;
import java.io.PipedInputStream;
public class ReadDate {
public void ReadDate(PipedInputStream input) {
try {
System.out.println("read:");
byte[] byteArray=new byte[20];
int readLength=input.read(byteArray);
while(readLength!=-1) {
String newDate=new String(byteArray,0,readLength);
System.out.print(newDate);
readLength=input.read(byteArray);
}
System.out.println();
input.close();
}catch(IOException e){
e.printStackTrace();
}
}
}
package pipeInputOutput;
import java.io.PipedOutputStream;
//輸出線程
public class ThreadWrite extends Thread {
private WriteDate write;
private PipedOutputStream out;
public ThreadWrite(WriteDate write,PipedOutputStream out) {
super();
this.write=write;
this.out=out;
}
public void run() {
write.writeMethod(out);
}
}
package pipeInputOutput;
import java.io.PipedInputStream;
//輸入線程
public class ThreadRead extends Thread{
private ReadDate read;
private PipedInputStream in;
public ThreadRead(ReadDate read,PipedInputStream in) {
super();
this.read=read;
this.in=in;
}
public void run() {
read.ReadDate(in);
}
}
package pipeInputOutput;
import java.io.IOException;
import java.io.PipedInputStream;
import java.io.PipedOutputStream;
//測試方法
public class Run {
public static void main(String[] args) {
try {
WriteDate write=new WriteDate();
ReadDate read=new ReadDate();
PipedInputStream inputStream=new PipedInputStream();
PipedOutputStream outputStream=new PipedOutputStream();
//輸出流與輸入流進(jìn)行連接。
outputStream.connect(inputStream);
//inputStream.connect(outputStream);
ThreadRead readThread=new ThreadRead(read,inputStream);
readThread.start();//先啟動(dòng)輸出線程
Thread.sleep(2000);
ThreadWrite writeThread=new ThreadWrite(write,outputStream);
writeThread.start();//后啟動(dòng)輸入線程
} catch (IOException e) {
e.printStackTrace();
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
控制臺輸出:
read:
write:
123456789101112131415161718192021...
123456789101112131415161718192021...
上面測試中,先啟動(dòng)輸入線程,然后因?yàn)闆]有線程被寫入所以線程被阻塞,知道有數(shù)據(jù)寫入。
我們接著繼續(xù)看看字符流的實(shí)現(xiàn)方法:
package pipeInputOutput1;
import java.io.IOException;
import java.io.PipedWriter;
//字符輸出流
public class WriteDate {
public void writeMethod(PipedWriter out) {
try {
System.out.println("write:");
for(int i=0;i<300;i++) {
String outDate=""+(i+1);
out.write(outDate);
System.out.print(outDate);
}
System.out.println();
out.close();
}catch(IOException e) {
e.printStackTrace();
}
}
}
package pipeInputOutput1;
import java.io.IOException;
import java.io.PipedReader;
//字符輸入流
public class ReadDate {
public void readMethod(PipedReader in) {
try {
System.out.println("read:");
char[] byteArray=new char[20];
int readLength=in.read(byteArray);
while(readLength!=-1) {
String newDate=new String(byteArray,0,readLength);
System.out.print(newDate);
readLength=in.read(byteArray);
}
System.out.println();
in.close();
} catch (IOException e) {
e.printStackTrace();
}
}
}
package pipeInputOutput1;
import java.io.PipedWriter;
//輸出流線程
public class WriteThread extends Thread {
private WriteDate write;
private PipedWriter out;
public WriteThread(WriteDate write,PipedWriter out) {
super();
this.write=write;
this.out=out;
}
public void run() {
write.writeMethod(out);
}
}
package pipeInputOutput1;
import java.io.PipedReader;
//輸入流線程
public class ReadThread extends Thread{
private ReadDate read;
private PipedReader in;
public ReadThread(ReadDate read,PipedReader in) {
super();
this.read=read;
this.in=in;
}
public void run() {
read.readMethod(in);
}
}
package pipeInputOutput1;
import java.io.IOException;
import java.io.PipedReader;
import java.io.PipedWriter;
//測試方法
public class run {
public static void main(String[] args) {
try {
WriteDate write=new WriteDate();
ReadDate read=new ReadDate();
PipedWriter out=new PipedWriter();
PipedReader in=new PipedReader();
//連接輸出流與輸入流
out.connect(in);
//in.connect(out);
ReadThread threadread=new ReadThread(read,in);
threadread.start();
Thread.sleep(2000);
WriteThread threadwrite=new WriteThread(write,out);
threadwrite.start();
} catch (IOException e) {
e.printStackTrace();
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
字符流額字節(jié)流大同小異,上面的例子中字符流不需要?jiǎng)?chuàng)建字節(jié)數(shù)組而已。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。
新聞標(biāo)題:java多線程編程之管道通信詳解
本文地址:http://chinadenli.net/article42/jggdec.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供動(dòng)態(tài)網(wǎng)站、網(wǎng)站設(shè)計(jì)、微信小程序、靜態(tài)網(wǎng)站、建站公司、搜索引擎優(yōu)化
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)