• 往线程池中动态添加任务示例


    import java.util.concurrent.BlockingQueue;
    import java.util.concurrent.ExecutorService;
    import java.util.concurrent.LinkedBlockingQueue;
    import java.util.concurrent.ThreadPoolExecutor;
    import java.util.concurrent.TimeUnit;
    
    public class ThreadPoolDynamicTasks extends Thread {
    
        private BlockingQueue<Runnable> bq = new LinkedBlockingQueue<>();// 可将此队列注入到客户端的子模块中
        private ExecutorService es = new ThreadPoolExecutor(2, 4, 0, TimeUnit.SECONDS, bq);
    
        private void init() {
            try {
                bq.put(new Runnable() {
    
                    @Override
                    public void run() {
                        while (true) {
                            try {
                                Thread.sleep(3000);
                            } catch (InterruptedException e) {
                                e.printStackTrace();
                            }
                            System.out.println("添加的任务");
                        }
                    }
                });
                bq.put(new Runnable() {
    
                    @Override
                    public void run() {
                        // while (true) {
                        try {
                            Thread.sleep(3000);
                        } catch (InterruptedException e) {
                            e.printStackTrace();
                        }
                        System.out.println("AAAAAA");
                        // }
                    }
                });
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
        }
    
        public static void main(String[] args) {
            ThreadPoolDynamicTasks instance = new ThreadPoolDynamicTasks();
            instance.init();// 阻塞队列中添加任务
            instance.start();// 利用线程循环遍历阻塞队列,每执行一个任务就移除一个任务
            instance.getTaskLengSize();// 获取阻塞队列里的任务数量
            try {
                Thread.sleep(3000);
                instance.addTask();// 在main线程中中途添加阻塞队列
                instance.getTaskLengSize();// 获取阻塞队列里的任务数量
                Thread.sleep(1000);
                instance.getTaskLengSize();// 获取阻塞队列的任务数量
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
    
        }
    
        @Override
        public void run() {
            while (true) {
                for (Runnable runnable : bq) {
                    // try {
                    // bq.take();
                    // } catch (InterruptedException e) {
                    // e.printStackTrace();
                    // }
                    es.execute(runnable);
                    bq.remove(runnable);
                }
            }
        }
    
        private void addTask() {
            try {
                bq.put(new Runnable() {
    
                    @Override
                    public void run() {
                        while (true) {
                            try {
                                Thread.sleep(3000);
                            } catch (InterruptedException e) {
                                e.printStackTrace();
                            }
                            System.out.println("~~~~~~~~~~~");
                        }
                    }
                });
                // es.execute(command);
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
        }
    
        private void getTaskLengSize() {
            System.out.println(bq.size());
        }
    
    }
    

      只要将任务队列注册到上下文容器中(例如web应用的servletContext、Eclipse应用的EclipseContext),注册到需要执行任务的java文件里,就可以用一个线程池执行所有的任务。

  • 相关阅读:
    NLog.Config的配置示例
    极限定义新讲:动态定义与静态定义
    rclone命令
    linux用户管理命令
    vim常用命令
    Python解二元二次方程组
    英雄联盟为什么这么难玩?——认识所有英雄
    snap安装、运行ss
    阿里云邮件推送服务Python API发送邮件
    Visual Studio #include<bits/stdc++.h>万能头文件
  • 原文地址:https://www.cnblogs.com/InformationGod/p/10537845.html
Copyright © 2020-2023  润新知