一般用JAVA写文件的方式:
byte[] buffer = new byte[1024];
while (fileIn.read(buffer) != -1)
{
outputStream.write(buffer);
}
但是这样会出现一个问题:如果最后读入buffer的数据只有n个字节,n小于1024个字节时,在buffer的[n,1024]区间存放的是上一次读取的数据,这样写入输出流的时候会导致比原文件要多出(1024-n)个字节。
应该使用如下的方式来写文件:
char[] cbuf = new char[CHAR_BUFFER];
int charsRead = 0 ;
while ((charsRead = br.read(cbuf)) != -1) {
bw.write(cbuf, 0, charsRead);
}
byte[] buffer = new byte[1024];
while (fileIn.read(buffer) != -1)
{
outputStream.write(buffer);
}
但是这样会出现一个问题:如果最后读入buffer的数据只有n个字节,n小于1024个字节时,在buffer的[n,1024]区间存放的是上一次读取的数据,这样写入输出流的时候会导致比原文件要多出(1024-n)个字节。
应该使用如下的方式来写文件:
char[] cbuf = new char[CHAR_BUFFER];
int charsRead = 0 ;
while ((charsRead = br.read(cbuf)) != -1) {
bw.write(cbuf, 0, charsRead);
}
此处的charsRead为每次实际读入的字节或字符数。
InputStream inStream = new FileInputStream(file);
byte[] buf = new byte[4096];
/*创建输出流*/
ServletOutputStream servletOS = response.getOutputStream();
int readLength;
while (((readLength = inStream.read(buf)) != -1)) {
servletOS.write(buf, 0, readLength);
}
inStream.close();
servletOS.flush();
servletOS.close();
本文介绍了使用Java进行文件读写时的一种更优方法,避免了因缓冲区未完全填满而导致的数据错误。通过示例代码展示了如何正确地处理每次实际读取到的字节数,确保文件内容完整且准确地被复制。

2万+

被折叠的 条评论
为什么被折叠?



