龙空技术网

IO字节输入流输出流的实用讲解

DDreamer 133

前言:

眼前同学们对“bytearrayoutputstream读取文件”大体比较关注,你们都想要剖析一些“bytearrayoutputstream读取文件”的相关文章。那么小编也在网摘上搜集了一些有关“bytearrayoutputstream读取文件””的相关知识,希望咱们能喜欢,小伙伴们快快来学习一下吧!

介绍IO流,主要是用于处理数据的传输,包含字节输入流,字节输出流,字符输入流,字符输出流,今天着重说下字节流;

所有的字节输入流继承 InputStream

InputStream,这个抽象类是表示输入字节流的所有类的超类。BufferedInputStream,当创建BufferedInputStream时,将创建一个内部缓冲区数组。 当从流中读取或跳过字节时,内部缓冲区将根据需要从所包含的输入流中重新填充,一次有多个字节。 mark操作会记住输入流中的一点,并且reset操作会导致从最近的mark操作之后读取的所有字节在从包含的输入流中取出新的字节之前重新读取。ByteArrayInputStream,包含一个内部缓冲区,其中包含可以从流中读取的字节; 内部计数器跟踪read方法要提供的下一个字节 。FileInputStream,获取文件输入流。

所有的字节输出流继承 OutputStream

OutputStream,这个抽象类是表示字节输出流的所有类的超类。 输出流接收输出字节并将其发送到某个接收器。BufferedOutputStream,该类实现缓冲输出流。 通过设置这样的输出流,应用程序可以向底层输出流写入字节,而不必为写入的每个字节导致底层系统的调用。ByteArrayOutputStream,该类实现了将数据写入字节数组的输出流。 当数据写入缓冲区时,缓冲区会自动增长。FileOutputStream,文件输出流是用于将数据写入到文件。

使用输入流输出流时注意是否需要成对出现,就好比大管道小管道似的,输入管道要与输出管道匹配才行。

IO流使用

使用以上介绍的输入输出流,简单的测试代码

BufferedInputStream

    public static void main(String[] args) {        try ( InputStream inputStream =new FileInputStream("E:\\测试.txt");//读取文件输入流              BufferedInputStream bufferedInputStream = new BufferedInputStream(inputStream);//声明BufferedInputStream              OutputStream outputStream = new FileOutputStream("E:\\测试输出.txt");              BufferedOutputStream bufferedOutputStream = new BufferedOutputStream(outputStream)                ){            //每次读取1024个字节            byte[] buffer=new byte[1024];            int len;            //读到文件末尾时返回-1            while ((len = bufferedInputStream.read(buffer))!=-1){                //b - 数据。                //off - 数据中的起始偏移量。                //len - 要写入的字节数。                bufferedOutputStream.write(buffer,0,len);            }            bufferedOutputStream.flush();//刷新此输出流,并强制将任何缓冲的输出字节写入流        } catch (FileNotFoundException e) {            e.printStackTrace();        } catch (IOException e) {            e.printStackTrace();        }    }
ByteArrayOutputStream

读取固定的字节数,效率上肯定是有一定的影响的

    public static void main(String[] args) {        try(InputStream inputStream =new FileInputStream("E:\\测试.txt");//读取文件输入流            ByteArrayOutputStream outputStream = new ByteArrayOutputStream()) {            int len = -1;            byte[] buffer = new byte[1024];            while ((len = inputStream.read(buffer)) != -1) {                outputStream.write(buffer, 0, len);            }            System.out.println(outputStream.toString("gb2312"));        } catch (FileNotFoundException e) {            e.printStackTrace();        } catch (IOException e) {            e.printStackTrace();        }    }

接着使用StreamUtils或者Hutool工具转换文件输入流为字节数组

    public static void main(String[] args) {        try(InputStream inputStream =new FileInputStream("E:\\测试.txt");//读取文件输入流            ByteArrayOutputStream outputStream = new ByteArrayOutputStream()) {            byte[] bytes = StreamUtils.copyToByteArray(inputStream);            outputStream.write(bytes);            System.out.println(outputStream.toString("gb2312"));        } catch (FileNotFoundException e) {            e.printStackTrace();        } catch (IOException e) {            e.printStackTrace();        }    }
遇到的问题

使用流操作时,就一定要注意资源是否关闭,如果是手动关闭,则需要注意的是关闭的顺序,遵循后打开的流先关闭的顺序。

如果非正常关闭,则会造成资源的浪费,文件的写入错误,如zip文件会出现 “不可预料的压缩文件末端”导致无法打开。

标签: #bytearrayoutputstream读取文件 #bytearrayinputstream读取文件