Android Thread线程池管理类

版权声明:未经博主同意切勿转载 https://blog.csdn.net/qq_32136827/article/details/83781310
package com.yunduan.parking.manager;

/**
 * author cowards
 * created on 2018\10\17 0017
 **/

import java.util.concurrent.ArrayBlockingQueue;
import java.util.concurrent.LinkedBlockingQueue;
import java.util.concurrent.RejectedExecutionHandler;
import java.util.concurrent.ThreadPoolExecutor;
import java.util.concurrent.TimeUnit;

/**
 * 1.  线程池管理类
 */
public class ThreadPoolManager {
    //1.将请求任务放到请求队列中
    //通过阻塞式队列来存储任务
    private LinkedBlockingQueue<Runnable> queue = new LinkedBlockingQueue<>();

    //2.把队列中的任务放到线程池
    private ThreadPoolExecutor threadPoolExecutor;

    private LinkedBlockingQueue<Runnable> removeTask = new LinkedBlockingQueue<>();

    //单例模式
    private static ThreadPoolManager singleInstance = new ThreadPoolManager();

    public static ThreadPoolManager getSingleInstance() {
        return singleInstance;
    }

    //私有化的构造方法
    private ThreadPoolManager() {
        threadPoolExecutor = new ThreadPoolExecutor(4, 20, 15, TimeUnit.SECONDS, new ArrayBlockingQueue<Runnable>(4), rejectedExecutionHandler);
        //运行线程池
        threadPoolExecutor.execute(runnable);
    }

    //添加任务
    public void execute(Runnable runnable) {
        if (runnable != null) {
            try {
                queue.put(runnable);
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
        }
    }

    //当线程数超过maxPoolSize或者keep-alive时间超时时执行拒绝策略
    private RejectedExecutionHandler rejectedExecutionHandler = new RejectedExecutionHandler() {
        /**
         * @param runnable 超时被线程池抛弃的线程
         * @param threadPoolExecutor
         */
        @Override
        public void rejectedExecution(Runnable runnable, ThreadPoolExecutor threadPoolExecutor) {
            //将该线程重新放入请求队列中
            try {
                queue.put(runnable);
            } catch (InterruptedException e) {
                e.printStackTrace();
            }

        }
    };
    //3.让他们开始工作起来
    //整个的工作线程
    private Runnable runnable = new Runnable() {
        @Override
        public void run() {
            while (true) {
                Runnable runnable = null;
                //不断从从请求队列中取出请求
                try {
                    runnable = queue.take();
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
                //如果不为空,放入线程池中执行
                if (runnable != null) {
                    if (!removeTask.contains(runnable)) {
                        threadPoolExecutor.execute(runnable);
                    }
                }
            }
        }
    };

    public void remove(Runnable runnable) {
        try {
            removeTask.put(runnable);
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
    }

    public void reset() {
        removeTask.clear();
        queue.clear();
    }
}

猜你喜欢

转载自blog.csdn.net/qq_32136827/article/details/83781310