java 线程间的通信 pipedOutStream 和PipedInputStream 管道流
2015-05-13 20:28
495 查看
package Test1;
import java.io.*;
import java.util.*;
class Send implements Runnable{//定义管道输出流
private OutputStream pipeoutput;
private String name;
public Send(String name){
this.setPipeinput(name);
}
public void setPipeinput(String name){
this.name=name;
this.pipeoutput=new PipedOutputStream();
}
public PipedOutputStream getPipeoutput(){
return (PipedOutputStream)this.pipeoutput;
}
public void run(){
try{
this.pipeoutput.write(this.name.getBytes());
}catch(Exception e){
e.printStackTrace();
}
}
}
class Recive implements Runnable{//定义管道输入流
private InputStream pipeinput;
public Recive(){
this.setPipeinput();
}
public void setPipeinput(){
this.pipeinput=new PipedInputStream();
}
public PipedInputStream getPipeOutput(){
return (PipedInputStream)this.pipeinput;
}
public void run(){
byte b[]=new byte[1024];
int len=0;
try{
len=this.pipeinput.read(b);
}catch(IOException e){
e.printStackTrace();
}finally{
System.out.println(new String(b,0,len));
}
}
}
public class PipedDemo01 {//java线程间的通信
/**
* @param args
*/
public static void main(String[] args) throws Exception{
// TODO Auto-generated method stub
Send s=new Send("磊哥无敌");
Recive re=new Recive();
Thread S=new Thread(s);
Thread r=new Thread(re);
S.start();
r.start();
re.getPipeOutput().connect(s.getPipeoutput());
}
}
import java.io.*;
import java.util.*;
class Send implements Runnable{//定义管道输出流
private OutputStream pipeoutput;
private String name;
public Send(String name){
this.setPipeinput(name);
}
public void setPipeinput(String name){
this.name=name;
this.pipeoutput=new PipedOutputStream();
}
public PipedOutputStream getPipeoutput(){
return (PipedOutputStream)this.pipeoutput;
}
public void run(){
try{
this.pipeoutput.write(this.name.getBytes());
}catch(Exception e){
e.printStackTrace();
}
}
}
class Recive implements Runnable{//定义管道输入流
private InputStream pipeinput;
public Recive(){
this.setPipeinput();
}
public void setPipeinput(){
this.pipeinput=new PipedInputStream();
}
public PipedInputStream getPipeOutput(){
return (PipedInputStream)this.pipeinput;
}
public void run(){
byte b[]=new byte[1024];
int len=0;
try{
len=this.pipeinput.read(b);
}catch(IOException e){
e.printStackTrace();
}finally{
System.out.println(new String(b,0,len));
}
}
}
public class PipedDemo01 {//java线程间的通信
/**
* @param args
*/
public static void main(String[] args) throws Exception{
// TODO Auto-generated method stub
Send s=new Send("磊哥无敌");
Recive re=new Recive();
Thread S=new Thread(s);
Thread r=new Thread(re);
S.start();
r.start();
re.getPipeOutput().connect(s.getPipeoutput());
}
}
相关文章推荐
- 流----管道流 PipedInputStream()/PipedOutStream()
- java 管道流PipedOutputStream和PipedInputStream基本操作
- java 管道流的读写操作 用于两个线程之间的通信
- java 管道流的读写操作 用于两个线程之间的通信
- “黑马程序员”java_IO流之PipedInputStream管道流的使用
- java 管道流的读写操作 用于两个线程之间的通信
- Java IO--管道流PipedOutputStream/PipedInputStream
- 举例讲解Java中Piped管道输入输出流的线程通信控制
- java IO 管道流 关于两个线程通信的问题
- 黑马程序员——管道流:PipedInputStream和PipedOutputStream与线程的结合运用
- Java线程通信-管道流
- java_IO流之PipedInputStream管道流的使用
- 【Java并发编程】之十一:线程间通信中notify通知的遗漏(含代码)
- java线程间通信:生产者--消费者
- 管道流进行线程间通信
- java线程间通信_线程同步_等待唤醒机制
- 黑马程序员_Java基础_线程间通信,生产者消费者案例,jdk1.5锁机制,守护线程
- Java多线程与并发应用-(3)-传统线程通信技术及生产者消费者模式
- Java多线程知识点整理(线程间通信)
- Java的多线程-线程间的通信(4)