本文为提高使用 bufferedinputstream 时文件转换速度提供解决方案。
原始代码存在几个问题:
- 读取和存储数据到内存中:文件完全读取到内存中,对于大文件中,这可能会耗时并导致内存溢出。
- 阻塞读取:程序阻塞等待所有数据读取完毕,而无法同时执行其他操作。
- 未复用 http 连接:每个请求创建一个新连接,这会增加开销和延迟。
- 未释放资源:http 连接和流未正确关闭,导致等待超时和内存泄漏。
解决方案
方案 1:直接复制流
使用 ioutils.copy 等方法边读边写,从而避免数据缓冲到内存中:
ioutils.copy(connection.getinputstream(), response.getoutputstream());
方案 2:使用 nio
使用 nio 进行非阻塞传输,并使用更大的缓冲区提高效率:
try (ReadableByteChannel in = Channels.newChannel(new BufferedInputStream(connection.getInputStream())); WritableByteChannel out = Channels.newChannel(response.getOutputStream())) { ByteBuffer byteBuffer = ByteBuffer.allocate(65536); while (in.read(byteBuffer) != -1) { byteBuffer.flip(); out.write(byteBuffer); byteBuffer.clear(); } }
建议
- 使用更大的缓冲区(如 64 kb 或 128 kb)
- 复用 http 连接,可以减少延迟和开销
- 始终关闭资源,以释放连接和流