线程池经典问题-任务异常处理

大家好,我是小趴菜,关于线程池我们都听过,也可能用过,也有了解过底层源码实现的,但是今天不研究它的实现原理,我们来看一下,提交到线程池的任务如果有异常了,会有什么问题

案例实现

首先我们定义一个线程池,

js 复制代码
private static final ThreadPoolExecutor threadPool = new ThreadPoolExecutor(1, 2, 10,
        TimeUnit.SECONDS, new ArrayBlockingQueue<>(1),
        new ThreadFactory() {
            @Override
            public Thread newThread(Runnable r) {
                Thread t = new Thread(r);
                System.out.println("创建了线程===============================");
                t.setName("xpc-------------");
                return t;
            }
        });

然后定义一个任务的实现,让这个任务会抛出异常

js 复制代码
static class Task implements Runnable{

    @Override
    public void run() {
        
        int i = 1/0;

    }
}

定义一个main方法测试

js 复制代码
    public static void main(String[] args) throws Exception{

        for(int i = 0 ; i < 500000; i ++){
            threadPool.execute(new Task());
            Thread.sleep(100);
        }
        threadPool.shutdown();
    }

你会发现,如果整个任务有异常,你会发现会不断的创建线程

我们使用线程池的原因就是因为线程池可以复用线程,来解决不断创建线程,然后销毁线程的消耗

因为整个线程执行过程中出现异常,整个线程就中止了,所以下一个任务进来以后就会重新创建一个线程来执行整个任务

创建线程,销毁线程都是需要消耗资源的,所以必然会对服务器造成一定的压力

解决办法

把我们的任务类修改一下,用try{}catch(){}把我们的业务代码包裹起来

js 复制代码
static class Task implements Runnable{

    @Override
    public void run() {
        try{
            int i = 1/0;
        }catch (Exception e) {
            //在这里处理异常,比如业务补偿等,或者打印日志,等待人工处理
            System.out.println("任务执行异常了");
            return;
        }
    }
}

main方法

js 复制代码
    public static void main(String[] args) throws Exception{

        for(int i = 0 ; i < 500000; i ++){
            threadPool.execute(new Task());
        }
        threadPool.shutdown();
    }

你可以发现,就创建了两个线程,因为我们线程池设置的最大线程数就是两个,就避免了不断的创建线程整个问题

相关推荐
Apifox11 分钟前
如何在 Apifox 中使用「模块」合理地组织接口
前端·后端·测试
q_191328469514 分钟前
基于SpringBoot+Vue2的美食菜谱美食分享平台
java·spring boot·后端·计算机·毕业设计·美食
bcbnb14 分钟前
iOS 抓包工具有哪些,工具矩阵、职责分工与工程化选型建议
后端
Yeats_Liao15 分钟前
时序数据库系列(七):性能监控实战指标收集
数据库·后端·时序数据库
无心水18 分钟前
【中间件:Redis】1、Redis面试核心:线程模型深度解析(6.0前后变化+工作流程)
数据库·redis·面试·redis面试·redis原理·redis线程模型·后端技术
程序员古德23 分钟前
25年11月软考架构真题《论无服务器架构(Serverless)》考后复盘总结
云原生·架构·serverless
用户2217659279226 分钟前
如何使用第三方库处理多线程请求接口结果顺序问题?
后端
milanyangbo29 分钟前
从同步耦合到异步解耦:消息中间件如何重塑系统间的通信范式?
java·数据库·后端·缓存·中间件·架构
刘一说1 小时前
Spring Boot 中的定时任务:从基础调度到高可用实践
spring boot·后端·wpf
小坏讲微服务1 小时前
使用 Spring Cloud Gateway 实现集群
java·spring boot·分布式·后端·spring cloud·中间件·gateway