InputStream是抽象的,不会公开(也不公开其子级)内部数据对象。因此,“深度复制”
InputStream的唯一方法是创建ByteArrayOutputStream,然后在InputStream上执行read()之后,将此数据写入()到ByteArrayOutputStream。然后做:
newStream = new ByteArrayInputStream(byteArrayOutputStream.toArray());
如果您
mark()在InputStream 上使用,则实际上您无法撤消此 *** 作。这使您的流“已消耗”。
要“重用”您的InputStream,请避免使用mark(),然后在读取调用结束时使用reset()。然后,您将从流的开头开始阅读。
编辑:
顺便说一句,IOUtils使用以下简单代码片段复制InputStream:
public static int copy(InputStream input, OutputStream output) throws IOException{ byte[] buffer = new byte[DEFAULT_BUFFER_SIZE]; int count = 0; int n = 0; while (-1 != (n = input.read(buffer))) { output.write(buffer, 0, n); count += n; } return count; }
了解更多:http
:
//kickjava.com/src/org/apache/commons/io/CopyUtils.java.htm#ixzz13ymaCX9m
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)