它不是很慢,至少没有办法使其更快。但是这是错误的。如果文件足够大,该方法
read()将不会从拳头调用中返回所有字节。此方法返回它设法读取的字节数作为返回值。
正确的方法是在循环中调用此方法:
public static void copy(InputStream input, OutputStream output, int bufferSize) throws IOException { byte[] buf = new byte[bufferSize]; int bytesRead = input.read(buf); while (bytesRead != -1) { output.write(buf, 0, bytesRead); bytesRead = input.read(buf); } output.flush(); }如下调用:
ByteArrayOutputStream baos = new ByteArrayOutputStream();copy(new FileInputStream(myfile), baos);byte[] bytes = baos.toByteArray();
像这样的事情在很多包中都有实现,例如
FileUtils.readFileToByteArray()@Andrey Borisov(+1)提到的
编辑
我认为您的情况变慢的原因是您创建了如此庞大的数组。您确定您确实需要吗?尝试重新考虑您的设计。我相信您不必将此文件读入数组就可以逐步处理数据。



