`
Everyday都不同
  • 浏览: 723446 次
  • 性别: Icon_minigender_1
  • 来自: 宇宙
社区版块
存档分类
最新评论

一种利用线程池进行for循环处理的思想

阅读更多

在for里面,如果执行一次for里面的内容所需时间“较长”(相对而言),不妨改用线程池的方式。

如下测试:

public class ExecutorTest2 {
	private static final int loopNum = 1*10;  
    
    public static void main(String args[]) throws InterruptedException {  
    	ExecutorTest2 TestThreadPool = new ExecutorTest2();  
        long bt = System.currentTimeMillis();  
        TestThreadPool.m1();  
        long et2 = System.currentTimeMillis();  
        System.out.println("[1]耗时:"+(et2 - bt)+ "ms");  
        Thread thread = new Thread();  
        long at = System.currentTimeMillis();  
        TestThreadPool.m2();
        long et3 = System.currentTimeMillis();
        System.out.println("[2]耗时:"+(et3 - at)+ "ms");
          
    }  
  
    public void m1() {
        ExecutorService pool = Executors.newCachedThreadPool();  
        for (int index = 0; index < loopNum; index++) {  
            Runnable run = new Runnable() {  
                public void run() {  
                    try {  
                        new Thread().sleep(1000);  //模拟耗时操作
                    	System.out.println("[1]" + Thread.currentThread().getName());
                    } catch (Exception e) {  
                    }  
                }  
            }; 
            pool.execute(run);  
        }  
        System.out.println("[1] done!");
        pool.shutdown();  
    }  
  
    public void m2() { 
    	AtomicInteger connectionIds = new AtomicInteger(0);
        for (int index = 0; index < loopNum; index++) {  
            try {  
                new Thread().sleep(1000);  //模拟耗时操作
                System.out.println("[2]" + Thread.currentThread().getName());
                
            } catch (Exception e) {  
                e.printStackTrace();  
            } 
        }  
        System.out.println("[2] done!");
    }  
}

 打印结果:

[1] done!

[1]耗时:6ms

[1]pool-1-thread-9

[1]pool-1-thread-7

[1]pool-1-thread-2

[1]pool-1-thread-1

[1]pool-1-thread-3

[1]pool-1-thread-4

[1]pool-1-thread-6

[1]pool-1-thread-5

[1]pool-1-thread-10

[1]pool-1-thread-8

[2]main

[2]main

[2]main

[2]main

[2]main

[2]main

[2]main

[2]main

[2]main

[2]main

[2] done!

[2]耗时:10005ms

 

由打印结果可知:m1方法是用到了多线程的,多线程此时被线程池管理;而m2方法始终是main主线程执行的。

采用先把要执行的“耗时”内容放到一个线程的执行主体(run方法)里面,再用线程池执行该线程,可大大减少for循环的耗时。但这种情况不适合for次数较大的情形,因为每循环一次,就开辟一个线程,开销较大。注意这种不叫高并发,只是相当于原来由一个工人干的活现在由多个工人协作完成一样。

分享到:
评论
发表评论

文章已被作者锁定,不允许评论。

相关推荐

    Java croe java 思想

    书中详细介绍了变量、数据类型、运算符、控制结构(如if语句、for循环、while循环)以及方法的定义和调用。这些都是编写任何程序的基础,掌握这些知识能帮助初学者快速上手。 其次,Java的面向对象特性是其核心思想...

    Java编程思想练习题答案(代码)

    - 条件语句(if-else,switch)和循环(for,while,do-while)是程序流程控制的关键部分。练习题可能要求编写逻辑判断或循环实现特定功能。 - break和continue语句在循环中的作用,以及如何使用标签(labeled ...

    vertx for springboot

    综上所述,“vertx for springboot”项目通过整合Vert.x和Spring Boot,构建了一种高效的微服务架构,集成了Eureka服务发现,便于管理和监控微服务,同时也利用了Vert.x的高性能特性,适应了现代分布式系统的需求。...

    java 核心编程思想 thinking in Java

    2. **类与对象**:Java是一种面向对象的语言,书中详细讲解了类的定义、对象的创建、封装、继承、多态等核心概念。此外,还讨论了抽象类、接口、内部类以及匿名类的使用,这些都是理解面向对象编程的关键。 3. **...

    disruptor concurency pattern in c++.zip

    Disruptor并发模式是一种高效、低延迟的并发处理框架,最初由英国LMAX公司开发,现在已被广泛应用于高性能计算和实时系统中。本篇文章将详细介绍Disruptor模式,并探讨如何在C++中实现和应用这一模式。 Disruptor...

    JAVA+JDK实例开发宝典

    学习Java首先要理解其基本语法,包括变量、数据类型、运算符、流程控制(如if语句、for循环、while循环)以及函数的定义与调用。此外,类与对象的概念是Java的核心,包括封装、继承和多态三大特性。书中通过实例演示...

    java课件PPT完整版

    本讲重点介绍了Java的基础语法,包括变量的声明、数据类型(基本类型和引用类型)、运算符的使用、流程控制语句(如if条件语句、switch选择语句、for、while、do-while循环)。此外,还讲解了如何编写简单的Java程序...

    Stream流式计算、ForkJoin和异步回调.md

    - **Stream流式计算**:Stream流式计算是一种新的数据处理模型,它可以将数据源转化为流,然后对流进行各种操作(如过滤、映射、排序等),最后收集结果。 #### 1.3 示例 在给定的部分内容中,通过一个具体的例子...

    Java共享内存并行编程

    Java作为一种跨平台的语言,不仅在Web开发、企业级应用等领域有着广泛应用,而且在高性能计算领域也展现出了巨大的潜力。Java对多线程的支持使得开发者能够更方便地开发出并行程序。然而,直接使用Java线程API进行...

    C#游戏编程入门.pdf;C#游戏编程入门;游戏开发;游戏编程

    2. **控制结构**:包括条件语句(if/else)、循环语句(for/while)等,用于实现游戏中的逻辑分支和重复操作。 3. **函数与方法**:函数是完成特定任务的一段代码,可以接受参数并返回值。在游戏编程中,通过定义函数...

    epoll 套接字

    其中,Epoll(Event Poll)是Linux系统提供的一种高效、灵活的I/O多路复用机制,尤其适用于高并发的服务器场景。本教程将深入探讨Epoll套接字的基本概念、工作原理以及如何利用Epoll实现一个反射服务器。 **1. ...

    Java语言学习课件

    Java是由Sun Microsystems(现为Oracle公司)开发的一种跨平台、高性能的编程语言,以其“一次编写,到处运行”的特性著称。Java具有简洁、面向对象、健壮、安全、高效等特点,广泛应用于Web应用、移动应用、企业级...

    Flask官网开发手册(2.0.2).zip

    通过阅读《Flask官网开发手册(2.0.2)》,开发者不仅可以学习到Flask的基本用法,还能深入理解其设计思想和最佳实践,从而更好地利用这一框架构建高效、稳定的Web应用。无论是初学者还是经验丰富的开发者,都能从中...

    java 编程 150 例

    初学者首先要掌握声明变量、数据类型(如整型、浮点型、字符串、布尔型等)、运算符(算术、比较、逻辑、位操作等)以及控制流(if语句、switch语句、for循环、while循环等)。 2. **类与对象**: Java是面向对象的...

    java咖啡馆

    这本书以一种生动、富有洞察力的方式,将复杂的编程概念融入到轻松的咖啡馆氛围中,使得学习Java的过程更加愉快且易于理解。书中涵盖了Java的基础知识、进阶特性以及实际开发中的应用技巧,是Java初学者和进阶者的...

    Java基础教程

    - **类与对象**:Java是一种面向对象的语言,类是对象的蓝图,而对象则是类的实例。 - **封装**:通过访问修饰符(public, private, protected)控制成员的可见性,实现数据的保护。 - **继承**:允许一个类...

    Java学习路线实战版

    6. **控制流**:掌握if条件语句、switch选择结构、for循环、while循环和do-while循环。 7. **方法**:学习如何定义和调用方法,理解参数传递机制。 二、面向对象编程 1. **类与对象**:理解类作为对象的蓝图,以及...

    黑马JavaSE基础+进阶重难点精华版复习资料

    - **面向对象**:是一种编程思想,主要特征包括封装、继承、多态。 - **继承**:允许子类继承父类的属性和方法。 - **抽象类**:不能被实例化的类,通常包含一个或多个抽象方法。 - **细节**: - **super关键字*...

    java开发师常见编程题

    递归是一种重要的算法思想,通过不断调用自身来解决问题。本例中用于判断字符串是否为回文。 **示例代码:** ```java public class PalindromeCheck { public static boolean isPalindrome(String str) { return ...

    Java学习路线和规划

    Java作为一种广泛使用的编程语言,在软件开发领域占据着极其重要的位置。对于初学者来说,制定一个合理的Java学习计划至关重要。本文将详细介绍一个系统化的Java学习路径,帮助初学者从零基础逐步成长为能够独立完成...

Global site tag (gtag.js) - Google Analytics