/**
* 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();
}
}
}
}
- 浏览: 268572 次
- 性别:
- 来自: 上海
文章分类
- 全部博客 (187)
- spring (10)
- jquery (14)
- js (18)
- java (44)
- freemarker (7)
- 框架介绍 (1)
- tomcat (4)
- oracle (7)
- 喜欢的诗文 (4)
- linux (19)
- nokia (1)
- 那些事 (1)
- apache (3)
- dom4j (1)
- SOA (1)
- 企业架构 (2)
- baidu (1)
- svn (1)
- 测试 (4)
- liunx (0)
- memcahce (1)
- mysql (25)
- maven (4)
- 推广 (1)
- 网络 (1)
- vpn (1)
- drools (1)
- mongodb (1)
- redis (3)
- xlightweb (1)
- wifi (1)
- 学习资料 (1)
- git (1)
- 系统设计 (1)
- springboot (1)
- 自考 (0)
最新评论
-
zuo_qin_bo:
if(df==null){ //这个地方并发多的情况 ...
ThreadLocal解决dateFormat多线程错误 -
kongnan93:
好文!赞一个!!!!
jquery blockUI 居中显示 -
cxc_110928:
如果加上不能出现连续的数字或者字母 如 1234 abcd ...
用java 匹配一个数字和字母密码的正则表达式 -
wzwahl36:
http://www.atool.org/json2javab ...
JSON和JAVA的POJO的相互转换
发表评论
-
折半查找法
2019-06-17 18:11 391public static void main(String[ ... -
js 加密 java解密
2017-12-05 16:27 907https://github.com/noisyle/cr ... -
java工程师成长之路
2017-03-04 17:43 594一、基础篇 1.1 JVM 1.1.1. J ... -
java 启动jar
2017-03-04 15:40 1664#!/bin/sh PRG="$0&qu ... -
ThreadLocal解决dateFormat多线程错误
2016-09-19 17:44 2177出处 http://www.blogjava.net/ki ... -
设计模式
2016-06-02 17:11 509http://www.cnblogs.com/xing9010 ... -
list分页
2016-05-11 09:56 408//分批保存数据 if(null!=aassetO ... -
根据输入执行代码块
2015-05-11 17:25 699/** * f-road.com Inc. * Copyrig ... -
java装饰器模式
2015-03-17 18:00 866java装饰器模式 意图:动态的将责任附加到对象上什么 ... -
java适配器模式
2015-03-17 17:54 653定义:属于结构型模式,其主要作用是将一个类的接口转换成客户 ... -
Java垃圾回收机制
2015-02-04 09:43 749垃圾收集GC(Garbage Coll ... -
jvisualvm结合jstatd进行远程监控
2015-01-27 16:17 862jvisualvm是Jdk自带的,具体点,据说是jdk1 ... -
最佳线程数总结
2015-01-26 11:53 0最佳线程数: 性能压 ... -
线程dump
2015-01-26 11:19 0Java 的线程 线程是指 ... -
几种阻塞队列
2015-01-26 11:11 0转自:http://blog.csdn.net/yydcj/ ... -
线程池的原理及实现
2015-01-26 10:53 7121、线程池简介: ... -
线程同步通信技术-wait notify 用法
2014-10-22 20:58 711/** * * <pre> * 子线程 ... -
Cisco VPN Client 442
2014-10-18 21:17 162典型的Cisco VPN Client 442 错误,之前的 ... -
JDK安装
2014-10-18 15:15 756学习Java 开发的第一步就是构建开发环境,JDK(Java ... -
MultiThreadHttpClient
2014-09-15 17:05 459package com.froad.points.bankse ...
相关推荐
在.NET框架中,C#语言提供了丰富的功能来创建和使用自定义性能计数器,这是一种强大的工具,用于监视应用程序的性能。性能计数器能够帮助开发者实时了解程序运行时的关键指标,如CPU使用率、内存消耗、I/O操作等。在...
当其值持续超过每CPU的2倍,且CPU使用率没有相应上升时,可能需要考虑调整SQL Server的"max worker threads"设置,以减少等待工作线程的数量,并更好地利用线程池。 同时,对于多CPU服务器,若System Object的"% ...
6. **异常处理和资源管理**:由于性能计数器可能涉及系统资源,因此在使用完计数器后,记得使用`Dispose()`方法释放资源,防止内存泄漏。 7. **使用第三方库**:虽然`System.Diagnostics.PerformanceCounter`类提供...
为了实现线程数量的动态调整,我们需要一个机制来监控线程池的状态,例如,通过计数器跟踪当前的空闲线程数。当线程池需要扩展或收缩时,可以使用信号量或者原子操作来控制线程的创建和销毁。线程池的入口函数应该...
在"MyLinuxThread"这个文件中,很可能包含了线程池的具体实现代码,可以从中学习如何在Linux环境下创建、管理和使用线程池,以及如何处理线程间的同步和通信问题。通过对这个实例的分析和实践,可以深入理解线程池的...
4. **限制并发数**:描述中提到“允许5个客户端同时访问”,这表明服务器应用可能采用了某种机制来限制同时运行的线程数量,比如使用信号量或者计数器。这种策略有助于控制服务器的负载,防止过多的并发请求导致系统...
在传统的线程池中,任务的执行是由线程函数控制的,这并不符合人类的思维模式,使得程序员在使用时感到不便。本文介绍了一种模拟人类思维模式的线程池设计,它更便于程序员理解和操作。 线程池的核心思想是预先创建...
实现也很简单,一个简单的计数器,当请求进入熔断器时,执行 tryAcquire(),计数器加 1,结果大于阈值的话,就返回 false,发生信号量拒绝事件,执行降级逻辑。当请求离开熔断器时,执行 release(),计数器减 1。 ...
9. **C++中的线程池实现**:虽然C++标准库没有内置的线程池,但可以使用第三方库,如Intel的TBB(Threading Building Blocks)或Boost库中的线程池实现。此外,也可以自定义实现线程池,根据项目需求定制功能。 在...
8. **实例应用**:线程池常用于服务器端、GUI应用、批处理任务等场景,通过合理使用线程池,可以提高系统对高并发请求的处理能力。 综上所述,"易语言源码优易线程池.rar"提供的源代码是一个实践性的教学资源,可以...
5. **同步机制**:为了保证线程安全,线程池需要使用同步机制,如互斥锁(`pthread_mutex_t`)、条件变量(`pthread_cond_t`)。这些工具用于控制对共享数据的访问,防止数据竞争。 6. **线程池的初始化与销毁**:...
- 每个线程有自己的程序计数器、寄存器和栈,使得它们可以独立运行。 2. **线程池的概念**: - 线程池是一组预先创建的线程,待任务到来时分配给这些线程,而不是每次任务都创建新的线程。这减少了线程创建和销毁...
3. **线程池计数器**: - **Create Count**: 总共创建的线程数,反映了服务器处理并发请求的能力。 - **Active Count**: 当前活动的线程数量,过高可能意味着系统正在处理大量请求。 - **Pool Size**: 线程池的...
在Linux操作系统中,C语言是系统编程的基础,用于构建高效且低级别的软件。线程池是一种多线程处理形式,预先创建一...通过理解和掌握如何在Linux下使用C语言实现线程池,开发者可以更有效地编写高并发、高性能的系统。
2. 添加任务:使用`pthread_mutex_lock()`锁定任务队列,将任务插入队列,然后使用`pthread_cond_signal()`通知线程池有新任务。 3. 工作线程:循环检查任务队列,当有任务时,使用`pthread_mutex_lock()`获取任务...
1. **线程基础**:线程是操作系统分配CPU时间的基本单位,一个进程可以包含多个线程,它们共享进程的内存空间,但拥有各自的栈空间和程序计数器。线程的创建、同步和通信是线程编程的基本操作。 2. **线程创建**:...
idleWorkers原子计数器用于跟踪当前空闲的工作线程数量,shutdown标志用于控制线程池是否已经关闭。 线程池的核心组件,如任务队列、工作线程集合和状态标志,都是线程安全的,这使得OrderedThreadPoolExecutor能够...
Redis,作为一个高性能的键值数据存储系统,广泛应用于缓存、消息队列、计数器等多个场景。在本文中,我们将深入探讨如何在Java环境中,特别是在Spring框架下,实现全面的Redis线程池配置,包括Redis Cluster线程池...
在本项目中,我们关注的是一个使用C语言实现的线程池,它已被测试在Linux环境下运行。下面将详细讨论线程池的基本概念、设计模式、以及C语言在实现线程池时可能涉及的关键技术。 1. **线程池基本概念** - **线程**...
Python内置了`concurrent.futures`模块,提供了线程池(ThreadPoolExecutor)和进程池(ProcessPoolExecutor)的实现,方便开发者使用。 **进程池**与线程池类似,但管理的是进程而不是线程。进程池同样可以提高...