简单的多线程并不能提高效率

下面是一个最简单的多线程处理程序。这种多线程处理并不能提高效率

private ExecutorService threadPool = Executors.newFixedThreadPool(2);

//..
Output process(Input input) {
    Future<Output> f = 
        threadPool.submit(() ->
           longTimeConsumingTask(input));
  return f.get();
}

这里似乎看到 longTimeConsumingTask 在其他线程里面并行计算,但可惜的是 f.get() 在这里同步等待。

这种方式其实和在本线程里面运行 longTimeConsumingTask 区别不大。

推荐阅读更多精彩内容