java 多线程 计算_如何在Java中多线程处理计算密集型代码段?

听起来像一个线程池会很好.基本上,你掀起了N个不同线程的集合,然后循环请求它们.请求将阻塞,直到线程可用.

ThreadPool pool = Executors.newFixedThreadPool(10); // 10 threads in the pool

ArrayList collectionOfCallables = new ArrayList( );

for (...) {

Callable callable = new Callable() { public Foo call() { COMPUTE INTENSIVE SECTION } }

collectionOfCallables.add(callable);

}

ArrayList> results = pool.invokeAll( collectionOfCallables );

pool.awaitTermination(5, TimeUnit.MINUTES ); // blocks till everything is done or 5 minutes have passed.

有了Future,你真的不需要等待终止. get()来自未来的结果将阻塞,直到相应的线程完成(或取消).

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值