0

我正在将字节从输入流传输到文件通道。由于处理器和文件 io 比网络快很多倍,因此很明显线程在传输数据时会暂停很多时间。是否可以实现下载文件的流水线概念,以便在每次暂停之间线程处理下一个获取请求所以单个线程正在处理多个获取请求?这是我的简单实现:

while (start < end && currentState.get() == 1) {
      delta = fileChannel.transferFrom(inputChannel, start, 8192);
      start += delta;
      }

欢迎任何其他提高速度的想法。

4

1 回答 1

2

有两种方法:

  1. 将您的代码完全重写为面向事件的范例(最好的办法是使用 Netty);

  2. 使用 Java 对多线程的出色支持。在这种情况下,您可以保留大部分阻塞 I/O 代码。

于 2014-08-24T11:59:33.997 回答