java.io包 管道流使用案例

package io;

import java.io.IOException;
import java.io.PipedInputStream;
import java.io.PipedOutputStream;

/***
* 管道流:
* 作用:两个线程间的通信
* 在PipedOutputStream类上具有下面方法:
* public void connect(PipedInputStream snk);
* 线程启动后,后自动进行管道的输入、输出操作;
* @author huawei
*
*/
public class PipedIO {
public static void main(String[] args) {
Send s = new Send();
Receive r = new Receive();
try{
s.getPos().connect(r.getPis());//连接管道
}catch(IOException e){
e.printStackTrace();
}
new Thread(s).start();
new Thread(r).start();
}
}
/*线程:写入数据*/
class Send implements Runnable{
private PipedOutputStream pos = null;
public Send(){
this.pos = new PipedOutputStream();
}
@Override
public void run() {
String str = "HELLO WORLD";
try{
this.pos.write(str.getBytes());
}catch(IOException e){
e.printStackTrace();
}

try{
this.pos.close();
}catch(IOException e){
e.printStackTrace();
}
}

public PipedOutputStream getPos(){
return this.pos;
}
}

/*线程:读出数据*/
class Receive implements Runnable{
private PipedInputStream pis = null;
public Receive() {
this.pis = new PipedInputStream();
}
@Override
public void run() {
byte[] b = new byte[1024];
int len = 0;
try{
len = this.pis.read(b);//接收数据
}catch(IOException e){
e.printStackTrace();
}

try{
this.pis.close();
}catch(IOException e){
e.printStackTrace();
}

System.out.println("接收的内容为: " + new String(b,0,len));
}

public PipedInputStream getPis(){
return pis;
}
}

你可能感兴趣的:(jvm,thread)