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) 方法,不过该方法不会影响文件