zoukankan      html  css  js  c++  java
  • Java实现inputstream流的复制

    获取到一个inputstream后,可能要多次利用它进行read的操作。由于流读过一次就不能再读了,而InputStream对象本身不能复制,而且它也没有实现Cloneable接口,所以得想点办法。

    实现思路:

    1、先把InputStream转化成ByteArrayOutputStream

    2、后面要使用InputStream对象时,再从ByteArrayOutputStream转化回来
    package com.test;

    import java.io.ByteArrayInputStream;
    import java.io.ByteArrayOutputStream;
    import java.io.FileInputStream;
    import java.io.FileNotFoundException;
    import java.io.IOException;
    import java.io.InputStream;

    public class StreamOperateUtil {
    public static void main(String[] args) throws FileNotFoundException {

    InputStream input =  new FileInputStream("c:\test.txt"); 
        //InputStream input =  httpconn.getInputStream(); //这里可以写你获取到的流
        
        ByteArrayOutputStream baos = cloneInputStream(input);
        
        // 打开两个新的输入流  
        InputStream stream1 = new ByteArrayInputStream(baos.toByteArray());  
        InputStream stream2 = new ByteArrayInputStream(baos.toByteArray());
        
    }
    
    private static ByteArrayOutputStream cloneInputStream(InputStream input) {
        try {
            ByteArrayOutputStream baos = new ByteArrayOutputStream();
            byte[] buffer = new byte[1024];
            int len;
            while ((len = input.read(buffer)) > -1) {
                baos.write(buffer, 0, len);
            }
            baos.flush();
            return baos;
        } catch (IOException e) {
            e.printStackTrace();
            return null;
        }
    }

    }

  • 相关阅读:
    数据库复习之数据库系统概论
    C++前缀表达式和后缀表达式
    MySQL——排序和分页
    MySQL——联表查询
    MySQL——Where条件子句
    MySQL——DQL查询数据(Select)
    MySQL——外键、DML语言(添加、修改、删除)
    MySQL——数据库的操作、属性
    MySQL——简介和安装
    MySQL——数据库
  • 原文地址:https://www.cnblogs.com/xueblvip/p/12299887.html
Copyright © 2011-2022 走看看