并发实战值之----线程池--线程池中放任务
来源:互联网 发布:最佳的起床时间 知乎 编辑:程序博客网 时间: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来判断任务是否执行成功,通过future的get方法来获取返回值,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)Callable和Runnable两个接口都值声明了一个run()方法,唯一的区别就是Callable接口中的run()方法有返回值,而Runnable接口中的run()方法没有返回值;
- 并发实战值之----线程池--线程池中放任务
- 并发实战值之----线程池--线程池的作用
- 并发实战值之----线程池--线程池的创建
- 并发实战值之----线程的安全性
- 并发实战值之----线程池--线程池的关闭、监控
- Java 1.5并发包之二:任务与线程池
- Java并发编程之线程池任务监控
- JAVA线程之四----并发实战
- java并发编程实战之线程安全性
- java 并发编程实战 之 线程安全性
- Java多线程并发之 fork jion ,不同线程之间互帮互助,最快完成线程池任务。
- 并发实战——“JUC线程池”之线程池架构
- 并发实战——“JUC线程池”之线程池原理01(简介,数据结构,调度)
- 并发实战——“JUC线程池”之线程池原理02(源码解析)
- java并发 -线程池,任务执行
- Java线程并发库之线程池
- 【Java】并发之线程池
- 【Java】并发之线程池
- java中带标签的break 和 continue
- Eclipse开发过程中,加载类时候找…
- JAVA中继承的学习笔记
- 使用String类的intern方法快速比较…
- JAVA中String类和StringBuffer类的…
- 并发实战值之----线程池--线程池中放任务
- 查看电脑开关机时间
- WinCE平台上的DMA
- eclipse更改svn账号
- lua开发 -- eclipse lua 插件
- 4.3inch 480x272 Touch LCD (B) 模块
- 并发实战值之----线程池--线程池的关闭、监控
- C程序设计语言--宏定义
- go学习链接