多线程返回值

多线程返回值,避免阻塞提高效率。

public class CallableDemo1<V> implements Callable<V> {
   List<String> list=new ArrayList<String>();
	@Override
	public V call() throws Exception {
		Thread.sleep(10000);
		System.out.println("CallableDemo1 begin");
		  for(int i=0;i<5;i++){
			  list.add(Math.random()+"");
		  }
		  System.out.println("CallableDemo1 end"); 
//		  System.out.println(Thread1Test.ct);
//		  Thread1Test.ct.countDown();
		return (V) list;
	}

}
public class CallableDemo2<V> implements Callable<V> {
   List<String> list=new ArrayList<String>();
	@Override
	public V call() throws Exception {
		Thread.sleep(7000);
		System.out.println("CallableDemo2 begin");
		  for(int i=0;i<5;i++){
			  Date date=new Date();
			  list.add(Math.random()+"");
		  }
		System.out.println("CallableDemo2 end"); 
//		 Thread1Test.ct.countDown();
		return (V) list;
	}

}

普通线程池阻塞获取结果,测试结果

测试代码:

	public  void testCoutDown() throws InterruptedException, ExecutionException {
		ExecutorService exec = Executors.newCachedThreadPool();//工头
		Future<List<String>> result1=exec.submit(new CallableDemo1());
		Future<List<String>> result2=exec.submit(new CallableDemo2());
		long start=System.currentTimeMillis();
		System.out.println(result1.get());
		System.out.println((System.currentTimeMillis()-start)+"T1开始处理");
		System.out.println(result2.get());
		System.out.println("T2开始处理"+(System.currentTimeMillis()-start));

	}

 

使用CompletionService非阻塞获取结果,测试结果:

测试代码:

	public void testComplete() throws InterruptedException, ExecutionException{
		ExecutorService exec = Executors.newCachedThreadPool();//工头

		CompletionService<List<String>> service = new ExecutorCompletionService(exec);
		service.submit(new CallableDemo1());
		service.submit(new CallableDemo2());
		System.out.println("获取结果");
		
		long start = System.currentTimeMillis();
		for(int i=0;i<2;i++){
			List<String> list1 = service.take().get();
			System.out.println(list1+"\n"+(System.currentTimeMillis()-start)+"线程"+i +"开始处理");
		}
		
		System.out.println("所有线程结束"+(System.currentTimeMillis()-start));
	}

非阻塞获取,哪个线程先返回,哪个线程就先处理。而阻塞处理返回结果时候,是串行处理。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值