10个班级,每个班级20名学生,在指定的时间内查询每个班级学生的集合。

    1. package cn.com.ld.study.thread;
    2. import java.util.ArrayList;
    3. import java.util.Collection;
    4. import java.util.HashMap;
    5. import java.util.List;
    6. import java.util.Map;
    7. import java.util.concurrent.Callable;
    8. import java.util.concurrent.ExecutionException;
    9. import java.util.concurrent.ExecutorService;
    10. import java.util.concurrent.Executors;
    11. import java.util.concurrent.Future;
    12. import java.util.concurrent.TimeUnit;
    13. public class FutureTest {
    14. //缓存操作数据集
    15. private static final Map<Integer, List<Student>> sutdenMap = new HashMap<Integer, List<Student>>();
    16. //初始化操作数据
    17. static {
    18. List<Student> stuList = null;
    19. Student stu;
    20. for (int i = 0; i < 10; i++) {
    21. stuList = new ArrayList<Student>();
    22. for (int j = 0; j < 2; j++) {
    23. stu = new Student(j, "zld_" + i + "." + j, i);
    24. stuList.add(stu);
    25. }
    26. sutdenMap.put(i, stuList);
    27. }
    28. }
    29. public static class Student {
    30. private int id;
    31. private String name;
    32. private int classID;
    33. public Student(int id, String name, int classID) {
    34. this.id = id;
    35. this.name = name;
    36. this.classID = classID;
    37. }
    38. public String toString() {
    39. return Student.class.getName() + "(id:" + this.id + ",name:"
    40. + this.name + ")";
    41. }
    42. }
    43. /**
    44. * @filename: SearchTask
    45. * @description: 查询任务
    46. * @author lida
    47. * @date 2013-4-1 下午3:02:29
    48. */
    49. public static class SearchTask implements Callable<List<Student>> {
    50. public final int classID;
    51. public long sleepTime;
    52. /**
    53. * <p>Title: </p>
    54. * <p>Description: </p>
    55. * @param classID  班级编号
    56. * @param sleepTime  模拟操作所用的时间数(毫秒)
    57. */
    58. SearchTask(int classID, long sleepTime) {
    59. this.classID = classID;
    60. this.sleepTime = sleepTime;
    61. }
    62. @Override
    63. public List<Student> call() throws Exception {
    64. //模拟操作所用的时间数(毫秒)
    65. Thread.sleep(sleepTime);
    66. List<Student> stuList = sutdenMap.get(classID);
    67. return stuList;
    68. }
    69. }
    70. public static void main(String[] args) {
    71. FutureTest ft = new FutureTest();
    72. ExecutorService exec = Executors.newCachedThreadPool();
    73. List<SearchTask> searchTasks = new ArrayList<SearchTask>();
    74. SearchTask st;
    75. for (int i = 0; i < 10; i++) {
    76. st = new SearchTask(i, 2001);//指定2001 毫米为最大执行时间
    77. searchTasks.add(st);
    78. }
    79. try {
    80. //要求认为在2000毫秒内返回结果,否则取消执行。
    81. List<Future<List<Student>>> futures = exec.invokeAll(searchTasks,
    82. 2000, TimeUnit.MILLISECONDS);//invokeAll 第一个参数是任务列表;第二个参数是过期时间;第三个是过期时间单位
    83. for (Future<List<Student>> future : futures) {
    84. List<Student> students = future.get();
    85. for (Student student : students) {
    86. System.out.println(student.toString());
    87. }
    88. }
    89. exec.shutdown();
    90. } catch (InterruptedException e) {
    91. e.printStackTrace();
    92. Thread.interrupted();
    93. } catch (ExecutionException e) {
    94. e.printStackTrace();
    95. }
    96. }
    97. }
    98. http://zld406504302.iteye.com/blog/1840091

ExecutorService invokeAll 实例(转)的更多相关文章

  1. ExecutorService.invokeAny()和ExecutorService.invokeAll()的使用剖析

    ExecutorService是JDK并发工具包提供的一个核心接口,相当于一个线程池,提供执行任务和管理生命周期的方法.ExecutorService接口中的大部分API都是比较容易上手使用的,本文主 ...

  2. Java并发专题 带返回结果的批量任务运行 CompletionService ExecutorService.invokeAll

    转载请标明出处:http://blog.csdn.net/lmj623565791/article/details/27250059 普通情况下,我们使用Runnable作为主要的任务表示形式,可是R ...

  3. Java并发专题 带返回结果的批量任务执行 CompletionService ExecutorService.invokeAll(转)

    转载请标明出处:http://blog.csdn.net/lmj623565791/article/details/27250059 一般情况下,我们使用Runnable作为基本的任务表示形式,但是R ...

  4. java并发编程框架 Executor ExecutorService invokeall

    首先介绍两个重要的接口,Executor和ExecutorService,定义如下: public interface Executor { void execute(Runnable command ...

  5. 并发编程-concurrent指南-线程池ExecutorService的实例

    1.new Thread的弊端 执行一个异步任务你还只是如下new Thread吗? new Thread(new Runnable() { @Override public void run() { ...

  6. Java多线程学习笔记(二)——Executor,Executors,ExecutorService比较

    Executor:是Java线程池的超级接口:提供一个execute(Runnable command)方法;我们一般用它的继承接口ExecutorService. Executors:是java.u ...

  7. java高级---->Thread之ExecutorService的使用

    今天我们通过实例来学习一下ExecutorService的用法.我徒然学会了抗拒热闹,却还来不及透悟真正的冷清. ExecutorService的简单实例 一.ExecutorService的简单使用 ...

  8. Executor(一)ExecutorService 线程池

    Executor(一)ExecutorService 线程池 本篇主要涉及到的是 java.util.concurrent 包中的 ExecutorService.ExecutorService 就是 ...

  9. cocurrent包ExecutorService线程池

    16. 执行器服务 ExecutorService java.util.concurrent.ExecutorService 接口表示一个异步执行机制,使我们能够在后台执行任务.因此一个 Execut ...

随机推荐

  1. hdu2818行列匹配+排序

    题意:给定一个矩阵,矩阵上有的数字是1,有的是0,给定两种操作,交换某两行或者某两列,问是否能置换出对角线为1的矩阵 题解:能够置换出对角线是1的矩形要求有n个1既不在同一行也不再同一列,即行列匹配, ...

  2. Windows Phone开发(26):启动器与选择器之MediaPlayerLauncher和SearchTask

    原文:Windows Phone开发(26):启动器与选择器之MediaPlayerLauncher和SearchTask 启动器与选择器简单的地方在于,它们的使用方法几乎一模一样,从前面几节中,我相 ...

  3. LAMP一键安装包(Python版)

    去年有出一个python整的LAMP自动安装,不过比较傻,直接调用的yum 去安装了XXX...不过这次一样有用shell..我也想如何不调用shell 来弄一个LAMP自动安装部署啥啥的..不过尼玛 ...

  4. SlopOne推荐算法

    在开源框架taste中有SlopOne的Java实现,效果不错.使用movielens的数据,代码例如以下 代码 #coding:utf-8 import re import math #读取数据,并 ...

  5. selinux 工具下载地址

    http://userspace.selinuxproject.org/releases/ 里面包含了 Name Last modified Size Description Parent Direc ...

  6. leetcode——Evaluate Reverse Polish Notation 求算式值(AC)

    Evaluate the value of an arithmetic expression in Reverse Polish Notation. Valid operators are +, -, ...

  7. java反射机制性能优化

    import java.lang.reflect.InvocationTargetException; import java.lang.reflect.Method; import java.uti ...

  8. 华为编程大赛汇总----java

           以下华为编程比赛题目都是网上整理得到的,代码都是自己调试过的,由于网上java答案较少,欢迎大家批评指正,也希望对准备华为上机的童鞋们有一点点帮助.在练习的过程中成长,加油!~~  1. ...

  9. BZOJ 1324 Exca神剑 最小割

    标题效果:给定一个n*m矩阵.所有的格宝石之子,人们可选择起始位置,后除去宝石的当前位置的周围消失,然后你就可以走两步,重复上述过程 easy发现格儿子把它周围格孩子不能拿 因此,党格访问问题 黑白染 ...

  10. IOS上传文件开发

    IOS上传文件开发     在移动应用开发  文件形式上传是不可缺少的,近期把IOS这块文件上传文件代码简单的整理一下.假设大家有须要安卓这边的代码,本人也能够分享给大家! QQ群:74432915 ...