`
357029540
  • 浏览: 735817 次
  • 性别: Icon_minigender_1
  • 来自: 重庆
社区版块
存档分类
最新评论

自定义线程池简单介绍

    博客分类:
  • JAVA
 
阅读更多

       线程池的相关概念就不在这里说明了,百度一下有很多,这里简单表述一下如何实现一个自定义的线程池就行线程管理,我们如果要实现一个线程池对线程的管理,那么需要实现一下几点的思路:

1.如何管理线程

2.如何定义工作线程以及工作线程如何持续的保持运行状态

3.如何定义线程池大小及队列大小

4.如何提供接口给调用者使用

5.如何关闭线程池中的线程

接下来我们就一一的实现这几个问题。

1.我们需要定义一个队列来来管理线程,这里使用了LinkedBlockingQueue

// 1.定义一个存储线程队列
private LinkedBlockingQueue<Runnable> queue;

 2.因为是一个简单的测试,所以我们可以先定义一个内部类来实现工作线程

// 2.定义工作线程进行线程的执行
    class Worker extends Thread {

        private SelfThreadPoolExecutor threadPoolExecutor;

        public Worker(SelfThreadPoolExecutor poolExecutor) {
            this.threadPoolExecutor = poolExecutor;
        }

        @Override
        public void run() {
            Runnable task;
            while (threadPoolExecutor.receiveTask || threadPoolExecutor.queue.size() > 0) {
                try {
                    // 有线程则取出来,否则等待
                    System.out.println("准备消费线程");
                    task = threadPoolExecutor.queue.take();
                    if (task != null) {
                        task.run();
                        System.out.println("消费线程");
                    }
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
            }
        }
    }

 SelfThreadPoolExecutor是外部定义的整体类名

3.使用有参的构造方法进行线程池大小的管理

// 3.存放工作线程的集合
    private List<Worker> workerList;

    // 4.线程池初始化
    public SelfThreadPoolExecutor(int coreSize, int queueSize) {
        if (coreSize <= 0 || queueSize <= 0) {
            throw new IllegalArgumentException("参数不正确");
        }
        this.queue = new LinkedBlockingQueue<>(queueSize);
        // 线程安全的集合
        this.workerList = Collections.synchronizedList(new ArrayList<>());
        for (int i = 0; i < coreSize; i++) {
            Worker worker = new Worker(this);
            worker.start();
            workerList.add(worker);
        }
    }

4.定义阻塞和非阻塞的方式提供对应的接口

// 5.非阻塞的方法接口
    public boolean offer(Runnable task) {
        if (receiveTask) {
            return queue.offer(task);
        } else {
            return false;
        }
    }

    // 6.阻塞的方法接口
    public void put(Runnable task) {
        try {
            if (receiveTask) {
                queue.put(task);
            }
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
    }

6.进行线程池的关闭

// 7.线程池的关闭
    private boolean receiveTask = true;

    public void shutdown() {
        // 7.1.队列不再接收线程
        receiveTask = false;
        // 7.2.关闭处于wait或block的线程
        for (Thread thread : workerList) {
            if (Thread.State.BLOCKED.equals(thread.getState())
            || Thread.State.WAITING.equals(thread.getState())
            || Thread.State.TIMED_WAITING.equals(thread.getState())){
                thread.interrupt();
            }
        }
    }

 我们测试的方法如下:

public static void main(String [] args){
        SelfThreadPoolExecutor selfThreadPoolExecutor = new SelfThreadPoolExecutor(5,10);
        for(int i = 0;i < 20;i++){
            Runnable task = () ->{
                System.out.println("开启线程");
            };
            selfThreadPoolExecutor.put(task);
        }
        selfThreadPoolExecutor.shutdown();
    }

 运行结果是:

准备消费线程
准备消费线程
准备消费线程
准备消费线程
准备消费线程
开启线程
消费线程
准备消费线程
开启线程
消费线程
准备消费线程
开启线程
消费线程
准备消费线程
。。。。。。

 整体代码见附件。

 

0
0
分享到:
评论

相关推荐

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

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

    自定义线程池

    根据描述,`MyFunctions.dll`提供了一个自定义线程池的实现,其使用方法应很简单。通常,使用自定义线程池的步骤包括: - 引入DLL:在项目中引用`MyFunctions.dll`,这可以通过右键点击项目,选择“添加引用”,...

    C# 自定义线程池

    例如,`WindowsApplication31`可能是一个简单的控制台应用程序,用于展示如何使用自定义线程池,而`TheadPooling`可能是实现线程池功能的核心类库。 自定义线程池的实现通常会包括以下步骤: 1. 初始化线程池:...

    Android编程自定义线程池与用法示例

    Android编程自定义线程池与用法示例主要介绍了Android编程自定义线程池与用法,结合实例形式分析了Android线程池的功能、定义及简单使用方法。下面将详细说明标题和描述中所说的知识点。 一、概述: Android中...

    自定义实现Java线程池

    #### 三、自定义线程池设计 基于`Executor`接口,我们可以实现一个简单的线程池。首先,定义必要的属性: - `wc`: 当前线程数量。 - `coreThreadPool`: 核心线程数。 - `maxThreadPool`: 最大线程数。 - `...

    【并发编程】自定义简单线程池.pdf

    下面详细介绍自定义线程池的设计思路及实现: ##### 1. 概念图 自定义线程池的核心组成部分包括: - **阻塞队列** (`BlockingQueue`):暂存线程池中无法立即处理的任务。 - **线程池** (`ThreadPool`):包含一定...

    简单的线程池的.net实现

    本项目"简单的线程池的.net实现"提供了一个自定义线程池的示例,帮助开发者更好地理解和运用线程池。 首先,线程池的主要优点在于其资源管理效率。当任务到达时,线程池会检查是否有空闲线程可供使用,如果有的话,...

    Java并发编程相关源码集 包括多任务线程,线程池等.rar

    Java并发编程常见知识点源码集锦,涉及到对象锁,Executors多任务线程框架,线程池等... ConcurrentLinkedQueue、DelayQueue示例、自定义的线程拒绝策略、自定义线程池(使用有界队列)、自定义线程池(使用无界队列)。。。

    【java框架】SpringBoot(10) -- SpringBoot巧用 @Async提升API接口并发能力 .pdf

    Spring Boot默认提供了一个简单的线程池配置,如果需要自定义,可以在配置类中声明一个`ThreadPoolTaskExecutor` bean: ```java @Configuration @EnableAsync public class AsyncConfig { @Bean public ...

    线程池 线程池的介绍及简单实现

    在C++中,虽然标准库没有提供内置的线程池实现,但我们可以使用第三方库或者自定义实现。例如,可以使用Boost库中的`boost::threadpool`,或者基于C++11的`std::thread`自建线程池。自建线程池的基本步骤如下: 1. ...

    自定义实现Java线程池1-模拟jdk线程池执行流程1

    我们也将遵循这个设计,实现一个简单的线程池类`SampleThreadPoolExecutor`,它继承自`Executor`接口。 在`SampleThreadPoolExecutor`类中,我们需要关注以下几个关键属性: 1. `wc`: 工作中的线程数量 2. `...

    BlockingQueue队列自定义超时时间取消线程池任务

    现在我们来详细讨论如何利用这些技术实现“BlockingQueue队列自定义超时时间取消线程池任务”。 首先,`BlockingQueue`是一个并发容器,它遵循先进先出(FIFO)原则,具有阻塞性质,当队列满时,生产者线程会被阻塞...

    使用Vector实现简单线程池

    然而,如果我们想要从头开始理解线程池的工作原理,或者在特定场景下自定义线程池的行为,那么使用`Vector`来实现简单的线程池是一个很好的学习实践。 标题"使用Vector实现简单线程池"指的是将Java中的`Vector`类...

    简单的线程池模型 (Dephi版),线程池

    这为学习和自定义线程池提供了便利,可以深入理解其内部工作机制,并根据项目需求进行调整。 标签“线程池 Dephi”进一步确认了这个资源与Delphi编程语言和线程池技术的关联。在Delphi中,线程池的创建通常基于...

    线程池简单实现chenjiegui

    但需要注意的是,这些预定义的线程池可能无法满足所有需求,因此在面临复杂并发场景时,通常需要自定义`ThreadPoolExecutor`来更好地控制线程池的行为。 总的来说,线程池是多线程编程中不可或缺的一部分,它通过...

    19 自己动手丰衣足食—简单线程池实现.pdf

    通过自定义线程池,我们可以深入理解线程池的工作机制,这对于在实际项目中使用Java内置的`ExecutorService`或其他高级线程池实现(如`ThreadPoolExecutor`)非常有帮助。同时,这也为理解并发编程中的线程管理、...

    Python探索之自定义实现线程池

    Python中的线程池是一...总之,自定义线程池在Python中可以通过`queue`模块轻松实现,它能够有效地管理和调度线程,提高程序执行效率。在实际应用中,可以根据需求选择自定义实现或者使用内置的`ThreadPoolExecutor`。

    简单线程池与线程池检查的实现

    标题 "简单线程池与线程池检查的实现" 涉及到的是计算机编程中的多线程管理和优化,特别是线程池的概念及其检查机制。线程池是一种多线程处理形式,预先创建一定数量的线程,放入池中,当有任务需要执行时,直接从池...

    java内置线程池 !!!

    下面是一个简单的自定义线程池的示例代码: ```java import java.util.concurrent.*; public class CustomThreadPool { public static void main(String[] args) { // 自定义线程池 ExecutorService pool = new...

    基于事件(AOP)的concurrent线程池

    3. **自定义线程池**:扩展ThreadPoolExecutor,添加一个方法来提交任务,并在该方法中应用AOP代理。 4. **织入切面**:通过反射或者其他方式,将自定义的拦截器织入到任务执行过程中。 5. **使用线程池**:应用程序...

Global site tag (gtag.js) - Google Analytics