并发实战值之----线程池--线程池中放任务

来源:互联网 发布:最佳的起床时间 知乎 编辑:程序博客网 时间:2024/05/16 06:21

3,线程池中执行任务:

(1)通过execute()方法去执行任务(在外界看来是这样);

  我们可以使用execute提交的任务,但是execute方法没有返回值,所以无法判断任务知否被线程池执行成功。通过以下代码可知execute方法输入的任务是一个Runnable类的实例。

 

threadpool.execute(new Runnable(){

public void run() {//每个任务的内容

//do something

}

});

 

 

(2)如果我们想要得到任务执行后的返回值,可以使用submit 方法来提交任务,它会返回一个future,那么我们可以通过这个future来判断任务是否执行成功,通过futureget方法来获取返回值,get方法会阻塞住直到任务完成,而使用get(long timeout, TimeUnit unit)方法则会阻塞一段时间后立即返回,这时有可能任务没有执行完。

Future<String> future=

threadpool.submit(new Callable<String>(){

public String call() throws Exception {

//do something

return "结果";

}

 

});

注意:

(1)Future接口(实现实在FutureTask类)只是一个容器一样的东西,它记住任务执行后的返回值;

(2)CallableRunnable两个接口都值声明了一个run()方法,唯一的区别就是Callable接口中的run()方法有返回值,而Runnable接口中的run()方法没有返回值;

原创粉丝点击