`

线程池加计数器使用

    博客分类:
  • java
 
阅读更多

/**
 * f-road.com Inc.
 * Copyright (c) 2014 All Rights Reserved.
 */
package cn.com.froad.thread;

import java.util.concurrent.CountDownLatch;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;

/**
 * <pre>
 *  积分池加计数器使用
 * </pre>
 *
 * @author xueyunlong
 * @create 2014年7月31日 下午3:26:30
 * @modify
 * @since   JDK1.6
 */
public class ExecutorCountDownTest {
    public static String alllist="";
     public static void main(String[] args) { 
            CountDownLatch runningThreadNum = new CountDownLatch(10);
            ExecutorService executorService = Executors.newFixedThreadPool(10);
            // 创建10个任务并执行 
            for (int i = 0; i < 10; i++) { 
                executorService.execute(new MoreThread(runningThreadNum,String.valueOf(i))); 
            } 
            executorService.shutdown(); 
            try {
                runningThreadNum.await();
            } catch (InterruptedException e) {
                System.out.println(e);
            }
     
          System.out.println("alllist:"+alllist);
          alllist="";
        } 
    private static class MoreThread implements Runnable {
           
            private String value;//传入的数据列表
            private CountDownLatch runningThreadNum;

            public MoreThread(CountDownLatch runningThreadNum, String value) {
                this.runningThreadNum = runningThreadNum;
                this.value = value;
            }
            @Override
            public void run() {
                try {
                    Thread.sleep((long) (Math.random() * 10000)); 
                    //执行处理,调用接口
                    System.out.println("本次线程名称:"+Thread.currentThread().getName());
                    alllist +=value;
                    System.out.println(alllist);
                } catch (Exception e) {
                    e.printStackTrace();
                }finally{
                    runningThreadNum.countDown();
                }
            }
        }
    } 
     

分享到:
评论

相关推荐

    C# 创建自定义性能计数器

    在.NET框架中,C#语言提供了丰富的功能来创建和使用自定义性能计数器,这是一种强大的工具,用于监视应用程序的性能。性能计数器能够帮助开发者实时了解程序运行时的关键指标,如CPU使用率、内存消耗、I/O操作等。在...

    使用CPU计数器监视SQL Server性能的

    当其值持续超过每CPU的2倍,且CPU使用率没有相应上升时,可能需要考虑调整SQL Server的"max worker threads"设置,以减少等待工作线程的数量,并更好地利用线程池。 同时,对于多CPU服务器,若System Object的"% ...

    C# 通过读取windows性能计数器监控系统运行参数

    6. **异常处理和资源管理**:由于性能计数器可能涉及系统资源,因此在使用完计数器后,记得使用`Dispose()`方法释放资源,防止内存泄漏。 7. **使用第三方库**:虽然`System.Diagnostics.PerformanceCounter`类提供...

    c++ 线程池 即用版

    为了实现线程数量的动态调整,我们需要一个机制来监控线程池的状态,例如,通过计数器跟踪当前的空闲线程数。当线程池需要扩展或收缩时,可以使用信号量或者原子操作来控制线程的创建和销毁。线程池的入口函数应该...

    线程池实例(Linux)

    在"MyLinuxThread"这个文件中,很可能包含了线程池的具体实现代码,可以从中学习如何在Linux环境下创建、管理和使用线程池,以及如何处理线程间的同步和通信问题。通过对这个实例的分析和实践,可以深入理解线程池的...

    线程并发线程池

    4. **限制并发数**:描述中提到“允许5个客户端同时访问”,这表明服务器应用可能采用了某种机制来限制同时运行的线程数量,比如使用信号量或者计数器。这种策略有助于控制服务器的负载,防止过多的并发请求导致系统...

    一种模拟人类思维模式的线程池

    在传统的线程池中,任务的执行是由线程函数控制的,这并不符合人类的思维模式,使得程序员在使用时感到不便。本文介绍了一种模拟人类思维模式的线程池设计,它更便于程序员理解和操作。 线程池的核心思想是预先创建...

    Hystrix系列之信号量、线程池

    实现也很简单,一个简单的计数器,当请求进入熔断器时,执行 tryAcquire(),计数器加 1,结果大于阈值的话,就返回 false,发生信号量拒绝事件,执行降级逻辑。当请求离开熔断器时,执行 release(),计数器减 1。 ...

    线程池代码

    9. **C++中的线程池实现**:虽然C++标准库没有内置的线程池,但可以使用第三方库,如Intel的TBB(Threading Building Blocks)或Boost库中的线程池实现。此外,也可以自定义实现线程池,根据项目需求定制功能。 在...

    易语言源码优易线程池.rar

    8. **实例应用**:线程池常用于服务器端、GUI应用、批处理任务等场景,通过合理使用线程池,可以提高系统对高并发请求的处理能力。 综上所述,"易语言源码优易线程池.rar"提供的源代码是一个实践性的教学资源,可以...

    线程池实现代码(C代码版本)

    5. **同步机制**:为了保证线程安全,线程池需要使用同步机制,如互斥锁(`pthread_mutex_t`)、条件变量(`pthread_cond_t`)。这些工具用于控制对共享数据的访问,防止数据竞争。 6. **线程池的初始化与销毁**:...

    C语言线程池.zip

    - 每个线程有自己的程序计数器、寄存器和栈,使得它们可以独立运行。 2. **线程池的概念**: - 线程池是一组预先创建的线程,待任务到来时分配给这些线程,而不是每次任务都创建新的线程。这减少了线程创建和销毁...

    Websphere计数器说明.doc

    3. **线程池计数器**: - **Create Count**: 总共创建的线程数,反映了服务器处理并发请求的能力。 - **Active Count**: 当前活动的线程数量,过高可能意味着系统正在处理大量请求。 - **Pool Size**: 线程池的...

    linux下C语言实现线程池

    在Linux操作系统中,C语言是系统编程的基础,用于构建高效且低级别的软件。线程池是一种多线程处理形式,预先创建一...通过理解和掌握如何在Linux下使用C语言实现线程池,开发者可以更有效地编写高并发、高性能的系统。

    C语言实现的线程池.zip

    2. 添加任务:使用`pthread_mutex_lock()`锁定任务队列,将任务插入队列,然后使用`pthread_cond_signal()`通知线程池有新任务。 3. 工作线程:循环检查任务队列,当有任务时,使用`pthread_mutex_lock()`获取任务...

    线程池实现

    1. **线程基础**:线程是操作系统分配CPU时间的基本单位,一个进程可以包含多个线程,它们共享进程的内存空间,但拥有各自的栈空间和程序计数器。线程的创建、同步和通信是线程编程的基本操作。 2. **线程创建**:...

    Mina的线程池实现分析

    idleWorkers原子计数器用于跟踪当前空闲的工作线程数量,shutdown标志用于控制线程池是否已经关闭。 线程池的核心组件,如任务队列、工作线程集合和状态标志,都是线程安全的,这使得OrderedThreadPoolExecutor能够...

    最全redis线程池实现,Spring支持,redis Cluster线程池,主从Redis读写分离,sentenl读写分离等

    Redis,作为一个高性能的键值数据存储系统,广泛应用于缓存、消息队列、计数器等多个场景。在本文中,我们将深入探讨如何在Java环境中,特别是在Spring框架下,实现全面的Redis线程池配置,包括Redis Cluster线程池...

    用c写的一个关于线程池的代码

    在本项目中,我们关注的是一个使用C语言实现的线程池,它已被测试在Linux环境下运行。下面将详细讨论线程池的基本概念、设计模式、以及C语言在实现线程池时可能涉及的关键技术。 1. **线程池基本概念** - **线程**...

    六、进程池与线程池学习ppt

    Python内置了`concurrent.futures`模块,提供了线程池(ThreadPoolExecutor)和进程池(ProcessPoolExecutor)的实现,方便开发者使用。 **进程池**与线程池类似,但管理的是进程而不是线程。进程池同样可以提高...

Global site tag (gtag.js) - Google Analytics