`

CompleteService介绍和使用实例

阅读更多

当向Executor提交批处理任务时,并且希望在它们完成后获得结果,如果用FutureTask,你可以循环获取task,并用future.get()去获取结果,但是如果这个task没有完成,你就得阻塞在这里,这个实效性不高,其实在很多场合,其实你拿第一个任务结果时,此时结果并没有生成并阻塞,其实在阻塞在第一个任务时,第二个task的任务已经早就完成了,显然这种情况用future task不合适的,效率也不高的,实例如下:

 

实例一:用一个非complete Service完成的批量任务

package completeservice;

import java.util.Random;
import java.util.concurrent.Callable;
import java.util.concurrent.ExecutionException;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.Future;
import java.util.concurrent.FutureTask;


/**
 *
 *<p>Test</p>
 *<p>Description:</P>
 *<p>Company:Cisco CAS</p>
 *<p>Department:CAS</p>
 *@Author: Tommy Zhou
 *@Since: 1.0
 *@Version:Date:2011-5-11
 *
 **/

public class NonCompleteServiceTest {
   
    public static void main(String[] args) throws InterruptedException, ExecutionException {
        ExecutorService executorService = Executors.newFixedThreadPool(10);
        Future<String>[] futures = new FutureTask[10];
       
        /**
         * 产生一个随机数,模拟不同的任务的处理时间不同
         */
        for (int i = 0; i < 10; i++) {
            futures[i] = executorService.submit(new Callable<String>() {
                public String call(){
                    int rnt = new Random().nextInt(5);
                   
                    try {
                        Thread.sleep(rnt*1000);
                    } catch (InterruptedException e) {
                        // TODO Auto-generated catch block
                        e.printStackTrace();
                    }
                    System.out.println("run rnt = "+rnt);
                    return String.valueOf(rnt*1000);
                }
            });
        }
       
        /**
         * 获取结果时,如果任务没有完成,则阻塞,在顺序获取结果时,
         * 可能别的任务已经完成,显然效率不高
         */
        for (int i = 0; i < futures.length; i++) {
            System.out.println(futures[i].get());
        }
        executorService.shutdown();
    }

}

 

package completeservice;

import java.util.Random;
import java.util.concurrent.Callable;
import java.util.concurrent.CompletionService;
import java.util.concurrent.ExecutionException;
import java.util.concurrent.ExecutorCompletionService;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.Future;

/**
 *
 *<p>Test</p>
 *<p>Description:</P>
 *<p>Company:Cisco CAS</p>
 *<p>Department:CAS</p>
 *@Author: Tommy Zhou
 *@Since: 1.0
 *@Version:Date:2011-5-11
 *
 **/

public class CompleteServiceTest {
public static void main(String[] args) throws InterruptedException, ExecutionException {
    ExecutorService executorService = Executors.newFixedThreadPool(10);
   
   
    CompletionService<String> completionService = new ExecutorCompletionService<String>(executorService);
   
    /**
     * 产生一个随机数,模拟不同的任务的处理时间不同
     */
    for (int i = 0; i < 10; i++) {
        completionService.submit(new Callable<String>() {
            public String call(){
                int rnt = new Random().nextInt(5);
               
                try {
                    Thread.sleep(rnt*1000);
                } catch (InterruptedException e) {
                    // TODO Auto-generated catch block
                    e.printStackTrace();
                }
                System.out.println("run rnt = "+rnt);
                return String.valueOf(rnt*1000);
            }
        });
    }
   
    /**
     * 获取结果时,总是先拿到队列上已经存在的对象,这样不用依次等待结果
     * 显然效率更高
     */
    for (int i = 0; i < 10; i++) {
        Future<String> future = completionService.take();
        System.out.println(future.get());
    }
    executorService.shutdown();
}
}

 

 

分享到:
评论
1 楼 coolboyysy 2013-07-23  

相关推荐

    oracle删除和重建实例

    在这篇文章中,我们将介绍删除和重建 Oracle 实例的步骤和要点。 删除 Oracle 实例 删除 Oracle 实例是一个复杂的过程,需要遵循一定的步骤,以免出现意外错误。下面是删除 Oracle 实例的步骤: 1. 删除实例记录...

    GDB调试精粹及使用实例GDB调试精粹及使用实例

    GDB调试精粹及使用实例GDB调试精粹及使用实例GDB调试精粹及使用实例GDB调试精粹及使用实例GDB调试精粹及使用实例GDB调试精粹及使用实例GDB调试精粹及使用实例GDB调试精粹及使用实例GDB调试精粹及使用实例GDB调试精粹...

    LMS imagine.Lab AMESim系统建模和仿真实例教程

    付永领、齐海涛编著的《LMS Imagine.Lab AMESim系统建模和, 仿真实例教程》以“实例教程”的方式介绍了AMESim在UNIX工作站和个人, 计算机上的使用方法。全书共10章,主要内容包括初级实例、高级实例分, 析,高级特点...

    OpenStack web界面使用ISO镜像安装启动实例

    本文将深入探讨如何通过Horizon使用ISO镜像来安装和启动一个新的实例。 首先,ISO镜像是一个标准的光盘映像格式,通常用于存储软件安装程序,如操作系统。在OpenStack中,ISO镜像可以作为启动源,让用户能够像在...

    Visual C# .NET精彩编程实例集锦

    实例1 如何使用错误提醒控件 实例2 如何使用信息提示控件 实例3 如何使用菜单控件 实例4 如何使用工具栏控件 实例5 如何使用状态栏控件 实例6 如何使用托盘控件 实例7 如何使用标签页控件 实例8 如何使用进度条控件 ...

    sqlserver2008R2应用添加实例步骤

    - 使用实例名称和之前设置的登录凭证进行连接,以验证是否成功。 **步骤9:数据库还原** - 如果需要将现有的数据库还原到新实例中,请确保数据库名称保持不变。 - 使用SSMS或其他工具将数据库文件导入新实例,并...

    j2ee实例 j2ee实例j2ee实例

    在实例中,了解如何使用JNDI查找和注入依赖,可以提高代码的可扩展性和灵活性。 此外,安全是J2EE应用的重要组成部分。J2EE提供了一套强大的安全模型,包括角色基的安全性、SSL/TLS加密、容器管理的身份验证和授权...

    UDP实例和SPComm实例

    用Delphi开发的SPComm和UDP的使用实例

    C# WebSocket使用实例源码,包含服务端和客户端

    总的来说,这个"C# WebSocket使用实例"是一个很好的学习资源,它涵盖了WebSocket的基本概念和C#实现细节。通过研究和运行这个示例,开发者可以更好地理解和掌握WebSocket在实际项目中的应用,特别是在需要实时数据...

    ANSYS经典实例汇集(共72个例子).pdf

    本资源为ANSYS经典实例汇集,共72个例子,涵盖了ANSYS在结构分析、固体力学、热分析、流体分析、电磁分析等方面的应用实例,旨在帮助用户快速熟悉ANSYS软件的使用和实践。 知识点一:ANSYS SOLID65 环向布置钢筋的...

    labview55个经典实例

    12. **子VI和函数库**:通过创建子VI,可以实现代码重用和模块化,实例将展示如何创建和使用子VI。 13. **数据可视化**:LabVIEW强大的图表和图形功能会在实例中得到体现,如实时波形显示、数据统计图、3D图形等。 ...

    php+redis使用实例

    该文档是php+redis的简单实例,主要使用了get和set方法

    python 脚本实例 编程实例 入门实例

    本文将深入探讨这些"python 脚本实例 编程实例 入门实例",帮助你理解Python的基本概念和常用操作。 1. **变量与数据类型** Python中的数据类型包括整型(int)、浮点型(float)、字符串(str)和布尔型(bool)...

    100个C#初学者编程实例

    10. **LINQ查询**:学习使用Language Integrated Query(LINQ)可以更高效地处理数据,实例会介绍如何使用LINQ进行数据库查询、集合筛选等操作。 11. **多线程**:C#支持并发编程,通过Thread类和Task类,初学者...

    FPGA数字系统设计实例(带书签版本)

    本书介绍了使用Quartus Ⅱ7.0开发FPGA/CPLD数字系统的开发流程和设计方法,通过实例讲解,介绍了数字电路设计的原理图编辑、文本编辑和混合编辑的方法,并对大型数字系统设计实例进行了解析。本书还介绍了宏功能模块及...

    android开发实例大全_王东华

    实例031: 联合使用DatePicker和TimePicker 来选择日期和时间 65 实例032:动态分隔手机屏幕 68 实例033:使用ListActivity实现动态菜单 列表 71 实例034:加载手机磁盘中的文件 73 实例035:实现抽屉样式效果 76 ...

Global site tag (gtag.js) - Google Analytics