java读取文件输出流出现的问题
2011年08月01日
ServletOutputStream outStream = null; try { outStream = rundata.getResponse().getOutputStream(); } catch (IOException e1) { // TODO Auto-generated catch block e1.printStackTrace(); } try { FileInputStream inStream = new FileInputStream(file); byte[] b = new byte[1024]; int i = inStream.read(b); while (i > 0) { outStream.write(b); i = inStream.read(b); } inStream.close(); outStream.close(); } catch (IOException e) { e.printStackTrace(); }
从 inStream中每次读取1024个字节,如果最后一次从inStream读取的内容不到1024个字节,比如只有500个字节,那b的前面500个字节是对的,500-1024个字节是上一次读取出来的内容的500-1024个字节,所以必需在outStream.write(b)后面加上b = new byte[1024], 这样每次读取都是重新申请一块空间,b的内容就不是上一次读取的内容了,或者每次都将读取出来的字节数i做判断,写的时候只写这么多个字节。
2011年08月01日
ServletOutputStream outStream = null; try { outStream = rundata.getResponse().getOutputStream(); } catch (IOException e1) { // TODO Auto-generated catch block e1.printStackTrace(); } try { FileInputStream inStream = new FileInputStream(file); byte[] b = new byte[1024]; int i = inStream.read(b); while (i > 0) { outStream.write(b); i = inStream.read(b); } inStream.close(); outStream.close(); } catch (IOException e) { e.printStackTrace(); }
从 inStream中每次读取1024个字节,如果最后一次从inStream读取的内容不到1024个字节,比如只有500个字节,那b的前面500个字节是对的,500-1024个字节是上一次读取出来的内容的500-1024个字节,所以必需在outStream.write(b)后面加上b = new byte[1024], 这样每次读取都是重新申请一块空间,b的内容就不是上一次读取的内容了,或者每次都将读取出来的字节数i做判断,写的时候只写这么多个字节。
本文讨论了Java在处理文件输入输出流时遇到的问题,特别是如何正确地读取和写入文件内容,避免数据混乱。通过实例展示了在读取文件时,如果最后一部分数据不足指定大小,如何重新分配内存来确保数据的正确性。

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



