`

java中线程池

阅读更多
最近在看线程池的类容,自己动手实现一个
 package cn.RJ.utils;

import java.util.concurrent.LinkedBlockingQueue;
import java.util.concurrent.ThreadPoolExecutor;
import java.util.concurrent.TimeUnit;
import java.util.concurrent.locks.Condition;
import java.util.concurrent.locks.ReentrantLock;

/**
 * 线程池
 * @author RJ
 *
 */
public class MyThreadPool extends ThreadPoolExecutor {

	private static final int POOL_SIZE = 10;
	private boolean is_paused ;
	private ReentrantLock pause_lock = new ReentrantLock();
	private Condition unpaused = pause_lock.newCondition();
	
	public MyThreadPool(){
		super(POOL_SIZE,POOL_SIZE,0L,TimeUnit.SECONDS,new LinkedBlockingQueue<Runnable>(POOL_SIZE));
	}
	
	
	protected void beforeExecute(Thread t, Runnable r){
		super.beforeExecute(t, r);
		pause_lock.lock();
		try {
			while(is_paused){
				unpaused.await();
			}
		} catch (Exception e) {
			t.interrupt();
		}finally{
			pause_lock.unlock();
		}
	}
	
	
	public void pause(){
		pause_lock.lock();
		try {
			is_paused = true;
		}finally{
			pause_lock.unlock();
		} 
	}
	
	public void resume(){
		pause_lock.lock();
		try {
			is_paused = false;
			unpaused.signalAll();
		} finally{
			pause_lock.unlock();
		}
	}
		
}


分享到:
评论

相关推荐

    Java简单线程池 线程池中文文档

    简单的线程池程序+中文文档 包结构: com.tangkai.threadpool --SimpleThread.java 工作线程 --TestThreadPool.java 程序入口 --ThreadPoolManager.java 线程池管理类

    Java中线程池框架核心代码分析

    Java中线程池框架核心代码分析

    JAVA使用线程池查询大批量数据

    线程池是一种多线程处理形式,预先创建了若干个线程,当有任务需要执行时,会从线程池中取出一个线程来执行任务,任务执行完毕后,线程返回线程池中等待新的任务。这种机制避免了频繁创建和销毁线程带来的性能开销,...

    java线程池使用后到底要关闭吗

    因为线程池中仍然有很多线程在运行,占用系统资源,导致内存泄露和应用崩溃。 通过实例代码,我们可以看到,如果不关闭线程池,可能会导致内存泄露和应用崩溃。在代码中,我们创建了一个线程池,然后执行一个打印...

    Java线程池使用说明

    Java线程池是Java并发编程中的重要组件,它能够有效地管理和复用线程,从而提高程序的执行效率和降低资源消耗。在JDK 1.5版本之前,Java对线程池的支持非常有限,而在JDK 1.5之后,加入了java.util.concurrent包,...

    java线程池完整代码

    `ConsumeThreadPoolPara` 是一个 JavaBean,用于存储线程池的参数,包括最小和最大线程数、检查线程池中线程的周期等参数。该类实现了 Serializable 接口,用于序列化和反序列化。 三、解析 xml 程序代码 使用 ...

    JAVA经典线程池源码

    - 线程池中的线程如果在执行过程中遇到未捕获的异常,线程池默认会记录这个异常并终止该线程。 通过深入研究和使用本资源提供的"JAVA经典线程池源码",开发者不仅可以理解线程池的基本工作原理,还能学习到如何...

    java线程池封装j

    3. 当线程池中的线程数量大于核心线程数且小于最大线程数时,新任务会创建线程执行,同时将超出核心线程数的线程设置为非核心线程。 4. 当线程池线程数达到最大值并且工作队列已满,将根据拒绝策略处理新任务。 ###...

    一个通用的Java线程池类

    目标:Java中多线程技术是一个难点,但是也是一个核心技术。因为Java本身就是一个多线程语言。本人目前在给46班讲授Swing的网络编程--使用Swing来模拟真实的QQ实时聊天软件。因为涉及到Socket编程,所以一定会使用多...

    Java中Executors类中几种创建各类型线程池

    Java中Executors类中几种创建各类型线程池方法及简单实例

    Java编程中线程池的最大风险规避

    此时,如果没有空闲线程来执行任务A,那么线程池中的所有工作线程都将永久阻塞,形成死锁。 为了避免这类问题,需要仔细设计线程池的使用场景。例如,不要将需要等待其他任务执行结果的任务放入线程池的工作队列中...

    Java实现通用线程池

    PooledThread类继承自Thread类,用于实现线程池中的线程,PooledThread类提供了多个方法来管理线程池中的线程,例如putTask、putTasks、stopTasks、pauseTasks等方法;ThreadPool类用于管理线程池中的线程,提供了多...

    Java concurrency线程池之线程池原理(一)_动力节点Java学院整理

    Java concurrency线程池之线程池原理(一)_动力节点Java学院整理,动力节点口口相传的Java黄埔军校

    Java版线程池实现

    Java线程池是一种高效管理并发任务执行的机制,它通过预先创建并维护一定数量的线程,从而避免了频繁地创建和销毁线程所带来的性能开销。在Java中,线程池的实现主要依赖于`java.util.concurrent`包中的`...

    创建Java程序中线程池的详解

    2. **工作线程(Worker Threads)**:线程池中的线程,用于执行提交的任务。它们在没有任务时会等待,而不是立即销毁,这样可以避免频繁创建和销毁线程的开销。 3. **任务队列(Task Queue)**:一个队列用来存储待...

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

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

    自定义实现Java线程池

    ### 自定义实现Java线程池 #### 一、概述 在深入探讨自定义Java线程池之前,我们先简要回顾一下线程池的基本概念及其重要性。线程池是一种多线程处理形式,处理过程中将任务添加到队列,然后在创建线程后自动启动...

    深入理解Java线程池(PPT:原理+代码)

    通过剖析Java中线程池的原理,解读Java线程池源码,并给出线程池调用的示例,帮助理解线程池的基本原理。

    Java实现的线程池、消息队列功能

    线程池是一种线程使用模式,它预先创建了一组可重用的线程,当有任务需要执行时,不再直接创建新的线程,而是从线程池中取出一个空闲线程来执行任务,完成任务后线程返回到线程池而不是直接销毁。这样可以避免频繁地...

    java线程池知识.ppt

    java线程池知识、

Global site tag (gtag.js) - Google Analytics