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

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

private ExecutorService threadPool = Executors.newFixedThreadPool(2);

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

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

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

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容