Callable和Future的应用-笔记整理8

Callable和Future的应用


取得线程返回的结果


1.Future取得的结果类型和Callable返回的结果类型必须一致,这是通过泛型来实现的。

2.Callable要采用ExecutorSevicesubmit方法提交,返回的future对象可以取消任务。

3.CompletionService用于提交一组Callable任务,其take方法返回已完成的一个Callable任务对应的Future对象。


实例1:

public class CallableAndFuture {
	public static void main(String[] args) {
		  ExecutorService  singlethread = Executors.newSingleThreadExecutor();
		  Future<String> future=
			  		singlethread.submit(
			  				new Callable<String>() {
			  					public String call(){
			  						try {
										Thread.sleep(2000);
									} catch (InterruptedException e) {
										e.printStackTrace();
									}
			  						return "hello";
					  }
				}
				  );
		  
		  System.out.println("等待结果");
		  
		  try {
			  System.out.println("取到结果"+future.get());    //一直等待线程返回结果
		  } catch (InterruptedException e) {
			e.printStackTrace();
		  } catch (ExecutionException e) {
			e.printStackTrace();
	      }

		ExecutorService executor =	Executors.newFixedThreadPool(10);
		CompletionService<Integer> completion = new ExecutorCompletionService<Integer>(executor);
		for(int j=1;j<=10;j++){
			final int retVal =j;
			
			completion.submit(
				new Callable<Integer>(){
					public Integer call(){
					
					try {
						Thread.sleep(new Random().nextInt(5000));
						
					} catch (InterruptedException e) {
						e.printStackTrace();
					}
					return retVal;
					}
				}
				);
		}
		for (int i = 1; i <=10; i++) {
			 try {
				 System.out.println(completion.take().get());
				 
			 } catch (InterruptedException e) {
				e.printStackTrace();
			} catch (ExecutionException e) {
				e.printStackTrace();
			}
		}
	}
}


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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值