java 线程池以及submit
2015-08-04 21:48
441 查看
突然发现自己老啦
都要开始记笔记了 线程这块看了好几遍 都没记住~~ 索性看一点记一点好咯
们可能还会有以下需求:
1、需要取消某个任务的运行 (可以设置全局变量)
2、需要接收任务运行的结果
3、需要在一个任务出错时候,停止未运行任务的运行(通过抛出异常,捕获异常则可以继续运行)
那么我们会用到线程池的 submit 方法,我们的任务需要实现Callable接口,任务的返回值和其取消操作被封装在Future(FutureTask实现)内部
都要开始记笔记了 线程这块看了好几遍 都没记住~~ 索性看一点记一点好咯
们可能还会有以下需求:
1、需要取消某个任务的运行 (可以设置全局变量)
2、需要接收任务运行的结果
3、需要在一个任务出错时候,停止未运行任务的运行(通过抛出异常,捕获异常则可以继续运行)
那么我们会用到线程池的 submit 方法,我们的任务需要实现Callable接口,任务的返回值和其取消操作被封装在Future(FutureTask实现)内部
import java.util.ArrayList; import java.util.List; import java.util.Random; import java.util.concurrent.*; public class CallableTest { public static void main(String[] args) throws Exception { ExecutorService executorService = Executors.newCachedThreadPool(); List<Future> resultList = new ArrayList<Future>(); // 创建10个任务并执行 for (int i = 0; i < 10; i++) { // 使用ExecutorService执行Callable类型的任务,并将结果保存在future变量中 // 最终会实例化一个FutureTask对象,其run方法会调用Callable的call方法,并且支持cancel等操作 Future future = executorService.submit(new TaskWithResult(i)); resultList.add(future);// 将任务执行结果存储到List中 } executorService.shutdown(); // 遍历任务的结果,未执行完会阻塞 for (Future fs : resultList) { // 打印各个线程(任务)执行的结果 System.out.println(fs.isDone() + "=" + fs.get() + "=" + fs.isDone()); } } } class TaskWithResult implements Callable { private int id; public TaskWithResult(int id) { this.id = id; } @Override public String call() throws Exception { System.out.println("call()方法被调用!" + Thread.currentThread().getName()); boolean flag = new Random().nextBoolean(); if (flag) { System.out.println("异常撞击!"); throw new TaskException("Meet error in task." + Thread.currentThread().getName()); } Thread.sleep(2000); return "结果是:" + id; } } class TaskException extends Exception { TaskException(String message) { super(message); } }
相关文章推荐
- java字符流读取文件
- 使用JDK提供的ThreadLocal实现线程范围的共享变量(类似于Map<Thread,Variable>)
- Java中static 和final的区别
- java中使用非本地字体
- java之面向对象
- Java基础-常用API之String类
- Java(08-4)
- java发送邮件(4)
- spring mvc 中web.xml配置信息解释
- TreeSet集合,
- java中包的必要性
- Java_Web三大框架之Hibernate+HQL语言基础
- Java 异常处理机制
- java基础总结——内部类
- Java中的getResourceAsStream方法
- JAVA输入输出流
- Java通过Axis2发布WebService
- java大数用法
- Java日志框架——JCL(Log4J,Java Logging API )转SLF4J
- Java IO学习【20】PrintStream的学习