Java管道 PipedInputStream PipedOutputStream
来源:互联网 发布:云视通摄像头扫描软件 编辑:程序博客网 时间:2024/06/02 05:17
PipedInputStream产生用于写入相关 PipedOutputStream的数据,实现管道化概念
PipedOutputStream作为多线程中的数据源,将其与FilterInputStream对象相连以提供有用的接口
管道流的作用体现在:多线程时候任务之间的通信,比如读写数据(IO等),或者生产者消费者任务问题等等
管道输入流应该连接到管道输出流;管道输入流提供要写入管道输出流的所有数据字节。通常,数据由某个线程从 PipedInputStream
对象读取,并由其他线程将其写入到相应的PipedOutputStream
。不建议对这两个对象尝试使用单个线程,因为这样可能死锁线程。管道输入流包含一个缓冲区,可在缓冲区限定的范围内将读操作和写操作分离开。如果向连接管道输出流提供数据字节的线程不再存在,则认为该管道损坏了
可以将管道输出流连接到管道输入流来创建通信管道。管道输出流是管道的发送端。通常,数据由某个线程写入 PipedOutputStream
对象,并由其他线程从连接的PipedInputStream
读取。不建议对这两个对象尝试使用单个线程,因为这样可能会造成该线程死锁。如果某个线程正从连接的管道输入流中读取数据字节,但该线程不再处于活动状态,则该管道被视为处于损坏状态
下面例子基本显示了如何使用管道流
package com.xuesong.upc;
import java.io.IOException;
import java.io.PipedInputStream;
import java.io.PipedOutputStream;
class Sender implements Runnable {//我有两个线程,一个用来写数据,另一个用来读数据,两个线程的实现方式略显不同
PipedOutputStream out = new PipedOutputStream();
public PipedOutputStream getPipedOs() {
return out;
}
@Override
public void run() {
// TODO Auto-generated method stub
try {
out.write("hello this is xuesong".getBytes());
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} finally {
try {
out.close();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
}
class Receiver extends Thread {
PipedInputStream in = new PipedInputStream();
public PipedInputStream getPipedIs() {
return in;
}
@Override
public void run() {
// TODO Auto-generated method stub
//super.run();
byte[] myByte = new byte[1024];
try {
in.read(myByte);
System.out.println("your information is:"+new String(myByte)
.trim().toUpperCase());
in.close();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} finally {
//in.close();
}
}
}
public class PipedInputStreamTest {
/**
* @param xuesong
*/
public static void doTestPipe() {
Sender start = new Sender();
Receiver end = new Receiver();
PipedInputStream pis = end.getPipedIs();
PipedOutputStream pos = start.getPipedOs();
try {
pis.connect(pos);
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
start.run();
end.start();
}
public static void main(String[] args) {
// TODO Auto-generated method stub
doTestPipe();
}
}
- Java管道 PipedInputStream PipedOutputStream
- Java IO--管道流PipedOutputStream/PipedInputStream
- java 管道流之PipedOutputStream和PipedInputStream
- 管道PipedInputStream/PipedOutputStream类
- 管道PipedInputStream/PipedOutputStream类
- 管道PipedInputStream/PipedOutputStream类应用
- 管道流PipedInputStream 和PipedOutputStream
- PipedInputStream和PipedOutputStream管道流
- java 管道流PipedOutputStream和PipedInputStream基本操作
- java学习笔记:管道流PipedInputStream和PipedOutputStream
- Java-IO之管道(PipedInputStream和PipedOutputStream)
- 【java基础:IO】管道流PipedInputStream和PipedOutputStream的Demostration
- Java.PipedInputStream-PipedOutputStream
- Java IO - PipedOutputStream & PipedInputStream
- PipedInputStream and PipedOutputStream 实现管道通信
- 管道流PipedInputStream与PipedOutputStream操作实例
- PipedOutputStream和PipedInputStream管道实现线程通信
- Java 数据流2(PipedInputStream,PipedOutputStream)
- 常见JAVA代码查错题及答案
- android获取状态栏高度
- 使用fusioncharts实时数据库来生成报表,描述趋势
- 3.1 Maximum likelihood and least square
- DECODE函数实现列转行
- Java管道 PipedInputStream PipedOutputStream
- Reconnaissance 2(水题)
- JAVA面试常见编程题总结
- RID、DR、BDR以及广播多路访问、非广播多路访问实验
- ios 通过调用系统摄像头拍照,拍视频,然后写入文件
- RadioGroup 的分列换行
- FrameSize、WinSize、VisibleSize、VisibleOrigin概念理解
- hdu4607:Park Visit
- TIOBE 2014年11月编程语言排行榜 R跃升至12位