zoukankan      html  css  js  c++  java
  • java中write(byte[] b)与write(byte[] b,int off,int len)区别

    public static void copyInputStreamT0OutputStream(InputStream in, OutputStream out) {
    byte[] buffer = new byte[1024];
    if (null != in) {
    try {
          while (true) {
          int len = 0;
          if ((len = in.read(buffer)) == -1) {
                    out.flush();
                    return;
            }
           out.write(buffer, 0, len);

          out.write(buffer);
        }

      } catch (Exception e) {
           e.printStackTrace();
       }

      }

    }

       方法一:

          public int read(byte[] b)


    方法二:


    public int read(byte[] b ,int off,int len)
    这个方法是从此输入流中将最多 b.length 个字节的数据读入一个 byte 数组中

    如果文件大于1024字节,就一次读1024个字节,然后写出,写出后在读剩下的,依次循环输出,

    发现上传的文件,使用方法一总是比方法二大十几K

    查看jdk文档,文档中有write(byte[] b, int off, int len)和write(byte[] b).其中write(byte[ ] b,int off,int len)注释为:

           将指定 byte 数组中从偏移量off开始的len个字节写入此缓冲的输出流。一般来说,此方法将给定数组的字节存入此流的缓冲区中,根据需要将该缓冲区刷新,并转到底层输出流。但是,如果请求的长度至少与此流的缓冲区大小相同,则此方法将刷新该缓冲区并将各个字节直接写入底层输出流。因此多余的BufferedOutputStream将不必复制数据。

           果然我试了write(byte[ ] b,int off,int len)方法文件没有变大.查看源码.最后发现write(byte[ ]) 是调用了write(byte[] b,int off,int len),其中len总是数组的长度.

        问题就出在这里.在最后一次写入流时,len一般不会为读入字节的长度.除非文件大小刚好被BUFFER_SIZE整除.而通过 while ((len = in.read(buffer)) > 0){write(byte[] b,int off,int len) ,其中len为实际读入流的字节长度.所以这个方法不会增加文件大小,不会把多余的字节写进去.

           也不知道为什么sun在java中增加了write(byte[] b) 方法,不过该方法不会影响文件

    
    
    
  • 相关阅读:
    linux安装mysql5.6全流程
    linux安装redis集群全流程
    脑图-流程图-ppt制作工艺
    控制台添加log4net
    正则表达式非获取匹配的用法
    Win10查看已存储WiFi密码的两种方法
    redis中list set zset的区别
    Topshelf 搭建 Windows 服务
    SQLSERVER 自增列跳ID 1W-1K问题
    sqlserver 自增列(id)跳跃问题,一下就跳过一千多个id
  • 原文地址:https://www.cnblogs.com/renyuanwei/p/9208304.html
Copyright © 2011-2022 走看看