Android java 实现自己线程池

本文介绍了一个自定义线程池的Java实现,包括线程池的基本配置参数、任务执行流程、工作线程管理和线程池关闭机制。该线程池能够根据最小和最大线程数动态调整工作线程数量,并支持任务队列。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

/**
 * Created by johnny on 2017/2/24.
 */

public class MyThreadPool implements Executor {
    

    private int mMinThreadNum = 0;
    private int mMaxThreadNum = 5;

    private int mThreadKeepTime = 15000;//毫秒

    private LinkedList<Runnable> mTaskList = new LinkedList<>();

    private List<Worker> mWorkList;


    public MyThreadPool() {
        mWorkList = new ArrayList<>(mMaxThreadNum);
    }


    public MyThreadPool(int minThreadNum, int maxThreadNum, int threadKeepTime) {
        mMaxThreadNum = maxThreadNum;
        mMinThreadNum = minThreadNum;

        mThreadKeepTime = threadKeepTime;

        if (minThreadNum < 0 || minThreadNum <= maxThreadNum) {
            throw new IllegalArgumentException("minThreadNum 要大于0 并且小于maxThreadNum");
        }

        mWorkList = new ArrayList<>(mMaxThreadNum);
    }


    public synchronized void execute(Runnable command) {
        if (command == null)
            return;


        Worker worker;

        synchronized (mWorkList) {
            if (mWorkList.size() < mMinThreadNum) {
                createWorker(command);
                return;
            }

            worker = getIdleWorker();
            if (worker != null) {
                synchronized (worker) {
                    worker.mTask = command;
                    worker.notify();
                }
                return;
            }

            if (mWorkList.size() < mMaxThreadNum) {
                createWorker(command);
                return;
            }

        }


        synchronized (mTaskList) {
            mTaskList.add(command);
        }
    }


    public void shutdown() {
        synchronized (mWorkList) {
            while(mWorkList.size() > 0) {
                Worker worker = mWorkList.remove(0);
                if (worker != null) {
                    worker.mIsRunning = false;
                    worker.notify();
                }
            }
        }
    }

    private void createWorker(Runnable runnable) {
        Worker worker = new Worker(runnable);
        Thread thread = new Thread(worker, "MyThreadPool");
        mWorkList.add(worker);
        thread.start();
    }

    private Worker getIdleWorker() {
        for (int i = 0; i < mWorkList.size(); i++) {
            Worker worker = mWorkList.get(i);
            if (worker.mIsRunning && worker.mTask == null) {
                return worker;
            }
        }

        return null;
    }


    class Worker implements Runnable {

        private volatile long mLastRunTime;
        private volatile boolean mIsRunning = true;

        private volatile Runnable mTask;

        Worker(Runnable task) {
            mTask = task;
        }

        public void run() {
            while (mIsRunning) {
                if (mTask == null) {
                    synchronized (mTaskList) {
                      if (!mTaskList.isEmpty()) {
                          mTask = mTaskList.removeFirst();
                      }
                    }
                }

                if (mTask != null) {
                    mLastRunTime = System.currentTimeMillis();

                    mTask.run();
                    mTask = null;

                    mLastRunTime = System.currentTimeMillis();
                } else {
                    if ((System.currentTimeMillis() - mLastRunTime) >= mThreadKeepTime) {
                        synchronized (mWorkList) {
                            if (mTask != null){
                                continue;
                            }

                            if (mWorkList.size() > mMinThreadNum) {
                                
                                mWorkList.remove(this);
                                mIsRunning = false;
                                return;
                            }
                        }
                    }

                    try {
                        synchronized (this) {
                            if (mTask == null) {
                               
                                this.wait(mThreadKeepTime);
                            }
                        }
                    } catch (InterruptedException e) {
                        mIsRunning = false;
                        Thread.currentThread().interrupt();
                        synchronized (mWorkList) {
                            mWorkList.remove(this);
                        }
                    }
                }

            }
        }
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

一只大丑鱼

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值