`
xurichusheng
  • 浏览: 344947 次
  • 性别: Icon_minigender_1
  • 来自: 南京
社区版块
存档分类
最新评论

线程池示例

阅读更多

 

1. 创建线程池 ThreadPool.java

import java.util.concurrent.ExecutorService;
import java.util.concurrent.LinkedBlockingQueue;
import java.util.concurrent.ThreadPoolExecutor;
import java.util.concurrent.TimeUnit;

import org.apache.log4j.Logger;

/**
 * @ClassName: ThreadPool
 * @Description: 线程池
 * @author 
 * @company 
 * @date 2013-3-13
 * @version V1.0
 */

public final class ThreadPool {

	private static final Logger log = Logger.getLogger(ThreadPool.class);

	private ExecutorService pool = null;

	private static final ThreadPool instance = new ThreadPool();

	/** 线程池维护线程的最少数量 */
	private static final int corePoolSize = 10;
	/** 线程池维护线程的最大数量 */
	private static final int maximumPoolSize = 15;
	/** 线程池维护线程所允许的空闲时间.当线程数大于核心时,此为终止前多余的空闲线程等待新任务的最长时间 */
	private static final long keepAliveTime = 60;

	private ThreadPool() {
	}

	/**
	 * @Title: getInstance
	 * @Description: 初始化线程池
	 * @return:ThreadPool
	 * @author 
	 * @date 2013-3-13
	 */
	public static ThreadPool getInstance() {
		try {
			if (null == instance.pool) {

				synchronized (instance) {

					if (null == instance.pool) {
						instance.pool = new ThreadPoolExecutor(corePoolSize,
								maximumPoolSize, keepAliveTime,
								TimeUnit.SECONDS,
								new LinkedBlockingQueue<Runnable>());
					}
				}
			}
		} catch (Exception e) {
			log.error("线程池初始化失败:" + e.getMessage(), e);
		}

		return instance;
	}

	public ExecutorService getPool() {
		return pool;
	}

	public void setPool(ExecutorService pool) {
		this.pool = pool;
	}
}

 

2. 测试用例 TestVectorThread.java

import java.util.Vector;

public class TestVectorThread implements Runnable {

	public TestVectorThread() {}
	
	private Vector<String> vc;
	
	public TestVectorThread(Vector<String> vc) {
		this.vc = vc;
	}
	
	@Override
	public void run() {
		try {
			test(vc);
		} catch (Exception e) {
			e.printStackTrace();
		}
	}

	public void test(Vector<String> vc) throws Exception {

		CommonMethod.getLast(vc);
		CommonMethod.deleteLast(vc);
	}
}

 

3. 调用的方法  CommonMethod.java

import java.util.Vector;

public final class CommonMethod {

	private CommonMethod() {
	}

	/**
	 * @Title: getLast
	 * @Description: 获取最后一个元素
	 * @param vc 元素集合
	 * @return:String
	 * @author 
	 * @date 2013-3-13
	 */
	public static String getLast(Vector<String> vc) {

		synchronized (vc) {
			int lastIndex = vc.size() - 1;
			return vc.get(lastIndex);
		}
	}

	/**
	 * @Title: deleteLast
	 * @Description: 删除最后一个元素
	 * @param vc 元素集合
	 * @author 
	 * @date 2013-3-13
	 */
	public static void deleteLast(Vector<String> vc) {

		synchronized (vc) {
			int lastIndex = vc.size() - 1;
			vc.remove(lastIndex);
		}
	}
}

 

4. 测试 Test1.java

public class Test1 {

	@Test
	public void test1() {
		
		Vector<String> vc = new Vector<String>(10);

		vc.add("aaaa");
		vc.add("bbb");
		vc.add("ccc");
		vc.add("ddd");
		vc.add("eee");
		vc.add("fff");
		vc.add("ggg");
		vc.add("hhh");
		vc.add("iii");
		vc.add("jjj");
		vc.add("kkk");

		ThreadPool.getInstance().getPool().execute(new TestVectorThread(vc));
	}

}

 

 

分享到:
评论

相关推荐

    Python 使用threading+Queue实现线程池示例

    一、线程池 1、为什么需要使用线程池 1.1 创建/销毁线程伴随着系统开销,过于频繁的创建/销毁线程,会很大程度上影响处理效率。 记创建线程消耗时间T1,执行任务消耗时间T2,销毁线程消耗时间T3,如果T1+T3&gt;T2,那...

    linux线程池示例程序

    下面将详细解释线程池的工作原理、其优点以及如何在Linux环境下实现一个线程池示例程序。 线程池的工作原理: 线程池由几个关键组件组成:工作线程、任务队列和管理器。当有新的任务需要执行时,不会直接创建新线程...

    java 线程池示例(自己实现的参考别人的代码)

    NULL 博文链接:https://yulincqupt.iteye.com/blog/1673919

    C++ 线程池示例,VS2015编译通过

    一个简单的线程池示例,可以自定义线程数量和执行任务,代码简洁可扩展性强。在使用上也很方便。下面是一个简单的调用 int main() { xcyk::ThreadPool threadPool("xcyk"); SYSTEM_INFO SystemInfo; ...

    线程池示例代码

    `ThreadPoolDemo.rar`和`thread_pool.rar`可能是线程池的实现示例,可能包含了一些基本的线程池设计和使用方法。这些示例通常会展示如何初始化线程池,提交任务,以及在适当的时候关闭线程池。分析这些示例可以帮助...

    uThreadPool线程池示例(查找0-1亿之间的质数任务)

    总之,`uThreadPool线程池示例`是一个很好的学习资源,它演示了如何利用线程池处理大型计算任务,同时展示了多线程编程中的并发控制和任务调度。对于想要提升并发编程能力的开发者来说,这是一个值得研究的案例。

    java线程池示例(包含自定义拒绝策略) #资源达人分享计划#

    线程池示例(包含自定义拒绝策略),演示了如何创建一个线程池,以及添加到队列的过程,先添加到工作线程,然后是缓存队列,最后是创建临时线程

    uThreadPool.pas 线程池示例 DEMO 修正资源死锁

    此发布修改了原作者在线程池Free时的一点问题:“不能结束工作中的工作者线程(资源死锁)”。 用法: // 创建线程池 FThreadPool := TThreadsPool.Create(Self); // 创建线程池 FThreadPool.ThreadsMin := 5; // ...

    Java8并行流中自定义线程池操作示例

    Java8并行流中自定义线程池操作示例 Java8并行流中自定义线程池操作示例主要介绍了Java8并行流中自定义线程池操作,结合实例形式分析了并行流的相关概念、定义及自定义线程池的相关操作技巧。 1. 概览 Java8引入了...

    Java线程池示例代码.zip

    线程池的作用: 线程池作用就是限制系统中执行线程的数量。 根据系统的环境情况,可以自动或手动设置线程数量,达到运行的最佳效果;少了浪费了系统资源,多了造成系统拥挤效率不高。用线程池控制线程数量,其他...

    线程池使用示例(含源代码)

    在提供的"线程池示例"文件中,应该包含了创建和使用线程池的代码示例,你可以参考并进行扩展,例如添加更多任务、调整线程池参数,或者实现自定义的线程工厂和拒绝策略,以加深对线程池的理解。

    SpringBoot线程池详解含完整示例(值得珍藏)

    Spring Boot的线程池是Java并发编程的核心工具,它提供了高效管理并发任务的能力,从而优化系统性能和响应速度。在Spring Boot中,线程池的使用涵盖了多种类型的ExecutorService实现,包括SingleThreadExecutor、...

    VC++写的线程池示例

    在"VC++写的线程池示例"中,可能包含了这些核心组件的实现。源代码可能展示了如何定义和管理`CWinThread`的子类,以及如何使用MFC的同步机制(如`CSingleLock`或`CMutex`)来保证线程安全。此外,示例可能还包括任务...

    线程池实例(Linux)

    线程池是一种多线程处理形式,通过维护一组可重用线程来提高系统的响应速度和效率。在Linux系统中,实现线程池通常需要掌握以下几个核心知识点: 1. **线程基础**:线程是操作系统分配CPU时间的基本单位,一个进程...

    delphi线程池实例

    在编程领域,线程池是一种优化并发处理的机制,它管理一组预先创建的线程,以便根据需要分配任务,而不是每次需要执行新任务时都创建新的线程。Delphi,作为一个强大的面向对象的编程环境,提供了对线程池的支持,这...

    Java-Thread-Pool-example:一个简单的 Java 线程池示例

    Java线程池是一种高效管理并发任务的...这些示例可以帮助我们理解线程池的工作原理,以及如何根据实际情况选择合适的线程池配置。通过学习和实践,我们可以更好地理解和利用Java线程池,提高多线程环境下的程序性能。

Global site tag (gtag.js) - Google Analytics