java手写简易版自定义线程池

import java.util.LinkedList;
import java.util.List;
import java.util.concurrent.atomic.AtomicInteger;
import java.util.concurrent.locks.Condition;
import java.util.concurrent.locks.ReentrantLock;

public class DdqThreadPool {
    private static final class DdqThread extends Thread {
        private Runnable runnable;
        private final ReentrantLock reentrantLock = new ReentrantLock();
        private final Condition condition = reentrantLock.newCondition();

        public void setRunnable(Runnable runnable) {
            try {
                reentrantLock.lock();
                this.runnable = runnable;
                condition.signalAll();
            } catch (Exception exception) {
                throw new RuntimeException(exception);
            } finally {
                reentrantLock.unlock();
            }
        }

        @Override
        public void run() {
            while (true) {
                try {
                    reentrantLock.lock();
                    while (runnable == null) condition.await();
                    runnable.run();
                    runnable = null;
                } catch (Exception exception) {
                    throw new RuntimeException(exception);
                } finally {
                    reentrantLock.unlock();
                }
            }

        }
    }

    private List<DdqThread> threads;

    private AtomicInteger threadSize;

    private DdqThreadPool(List<DdqThread> ddqThreads) {
        this.threads = ddqThreads;
        this.threadSize = new AtomicInteger(ddqThreads.size());
    }

    public static DdqThreadPool newDdqThreadPool(int maxThreadSize) {
        if (maxThreadSize < 1) throw new IllegalArgumentException("线程数量必须大于0");
        List<DdqThread> ddqThreads = new LinkedList<>();
        for (int idx = 0; idx < maxThreadSize; idx++) {
            DdqThread ddqThread = new DdqThread();
            ddqThread.start();
            ddqThreads.add(ddqThread);
        }
        return new DdqThreadPool(ddqThreads);
    }

    public void execute(Runnable runnable) {
        if (runnable == null) throw new IllegalArgumentException("runnable不能为null");
        int oldThreadSize1 = threadSize.get();
        if (oldThreadSize1 < 1) return;
        if (!threadSize.compareAndSet(oldThreadSize1, oldThreadSize1 - 1)) return;
        DdqThread idleThread = threads.remove(0);
        idleThread.setRunnable(runnable);
        //以下三段代码可能还存在bug,因为idleThread.setRunnable(runnable)后,由于是异步执行,可能会存在着线程没执行完,但是忙碌线程又被添加回了可用线程集合
        int oldThreadSize2;
        while (!threadSize.compareAndSet((oldThreadSize2 = threadSize.get()), oldThreadSize2 + 1)) ;
        threads.add(idleThread);
    }
}

  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java中可以通过自定义线程池来管理线程的执行。可以使用@Async注解来指定线程池,如在@Component注解中使用@Async("taskExecutor")来指定线程池的名称为"taskExecutor"。\[1\]另外,还可以通过实现Callable接口并重写call()方法,然后使用FutureTask来获取线程的执行结果。\[2\]在线程池的使用方面,可以使用ExecutorService接口来创建线程池,例如使用Executors.newFixedThreadPool(3)来创建一个固定大小为3的线程池。\[3\]最后,记得在使用完线程池后调用shutdown()方法来关闭线程池。 #### 引用[.reference_title] - *1* [java自定义线程池总结](https://blog.csdn.net/qq_21225505/article/details/125092169)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [Java自定义线程池](https://blog.csdn.net/HcJsJqJSSM/article/details/123033019)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [Java创建线程池三种方式及自定义线程池](https://blog.csdn.net/Luck_ZZ/article/details/101057124)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值