Java线程--线程池Future、Callable

Future、Callable配套使用

Runnable与Callable区别:

  • Runnable接口:

一个独立的任务,任务执行的结果,无需告知主线程

Runnable接口中的方法为:void run(){}

  • Callable接口:

也是一个独立的任务,但是任务执行的结果,是主线程想要知晓的,因此可以配套Future接口,在将来的某个时间点,主线程可以获取到独立任务的执行结果,以便主线程拿来消费使用这个任务的执行成果

Callable接口中的方法为:T call(){}

示例代码:

/**
* 演示Future、Callable用法
*/

import java.util.concurrent.*;
import java.util.concurrent.locks.*;
import java.util.concurrent.atomic.*;

public class FutureTest{
    
    public static void main(String[] args){

		ExecutorService es = Executors.newFixedThreadPool(2);

		Future<Integer> f1 = es.submit(new MyTask());

		try{
			System.out.println("主线程痴痴的等子线程的运算结果!");
			Integer sum = f1.get();
			System.out.println("sum is :"+sum);
		}catch(Exception ee){}

		es.shutdown();

		System.out.println("main is over....");
    }
}

class MyTask implements Callable<Integer>
{
	public Integer call(){

		int sum = 0;
		for(int i=0;i<5000;i++){
			sum+=i;
		}

		try{
			Thread.sleep(2000);
			System.out.println("子线程运算完毕!");
		}catch(Exception ee){}

		return sum;
	}
}

程序运行结果如下:

主线程痴痴的等子线程的运算结果!
子线程运算完毕!
sum is :12497500
main is over....

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值