java中如何将OutputStream转换为InputStream

如果你曾经使用java IO编程,你会很快碰到这种情况,某个类在OutputStream上创建数据而你需要将它发送给某个需要从输入流读取数据的类。

你很快会被问道,“java中如何将OutputStream转换为InputStream?”

方法一:使用字节数组缓存数据

最简单的方法是用字节数组缓存数据。代码

ByteArrayOutputStream out = new ByteArrayOutputStream();

class1.putDataOnOutputStream(out);

class2.processDataFromInputStream(

new ByteArrayInputStream(out.toByteArray())

);

于是,OutputStream就被转换为InputStream了。

方法二:使用管道

第一种方法的问题是你必须有足够的内存缓存所有数据。你可以使用文件系统缓存更多数据,但无论如何可处理数据的大小还是受到限制。

解决方法是创建一个线程产生数据到PipedOutputStream。当前线程可从中读取数据。

PipedInputStream in = new PipedInputStream();

PipedOUtputStream out = new PipedOutputStream(in);

new Thread(

new Runnable(){

public void run(){

class1.putDataOnOutputStream(out);

}

}

).start();

class2.processDataFromInputStream(in);|||

方法三:使用循环缓存区

方法二中的两个管道流,实际上管理着一个隐藏的循环缓存区。使用一个显式的循环缓存区更易于理解。CircularBuffers 有如下优点

一个CircularBuffers类而不是两个管道类。

较于缓存所有数据和额外线程的方法更容易使用。

你可以更改缓存大小而不必受限于管道缓存区1K的固定缓存大小。

多线程情形:

CircularByteBuffer cbb = new CircularByteBuffer();

new Thread(

new Runnable(){

public void run(){

class1.putDataOnOutputStream(cbb.getOutputStream());

}

}

).start();

class2.processDataFromInputStream(cbb.getInputStream());

单线程情形

// buffer all data in a circular buffer of infinite size

CircularByteBuffer cbb = new CircularByteBuffer(CircularByteBuffer.INFINITE_SIZE);

class1.putDataOnOutputStream(cbb.getOutputStream());

class2.processDataFromInputStream(cbb.getInputStream());

你可能感兴趣的:(java,职场,如何,休闲)