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

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

案例实现

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

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();
    }

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

相关推荐
小强19881 小时前
为什么你建了索引,查询还是很慢?常见失效原因汇总
后端
长大19881 小时前
MySQL 索引到底是什么?普通人也能看懂的通俗讲解
后端
400分1 小时前
2026 年大模型应用开发之 Agent 意图路由实战指南,可运行代码(python)
架构
阿苟1 小时前
spring重点详解
java·后端·面试
一只叫煤球的猫1 小时前
用AI写业务代码后,必须要坚持自己做的几件事情——过程控制
面试·ai编程·vibecoding
l软件定制开发工作室2 小时前
Spring开发系列教程(35)——使用Actuator
java·后端·spring
小程故事多_802 小时前
生产级大模型应用后端架构设计指南(从入门到实战)
人工智能·架构·智能体
我叫黑大帅2 小时前
PyScript-GitHubRepo: 构建高性能GitHub仓库批量下载工具的技术实践
后端·python·面试
AI产品测评官3 小时前
2026年AI招聘架构深潜:多Agent协同如何打造主动出击智能体代表?
人工智能·架构
平凡但不平庸的码农3 小时前
Go 错误处理详解
开发语言·后端·golang