Spring Boot整合线程池出现的问题

一、前言

项目需要,加上本人没怎么用过线程池,异步线程这种,便想学习一下。

 

实现线程有两种,继承Thread和实现Runable接口。不了解的稍微去了解一下。

楼主一开始用的是实现Runable接口

这里楼主需要传递参数进去,所以重新定义了一个接口去实现

public interface MyRunable extends Runnable {
    // 注意:如果想要传递参数给异步线程,则重新定义抽象方法去实现
    void setParam(Object obj);
}

之后实现该接口

public class ThreadTask implements MyRunable {
    private Object object;
    @Override
    public void setParam(Object obj) {
        object = obj;
    }

    @Override
    public void run() {
        System.out.println("xiaoshishu >>> 传递进来的参数" + object.hashCode());
    }
}

遇到的坑:因为需要增删改查,调用数据库那边,接口一直报空指针异常;

解决方法:直接定义一个工具类,通过类名直接去Spring上下文获取即可,但是这种方法我不太喜欢。也找不到好的解决方法,后面抛弃掉使用线程池。

2、配置线程池

整合线程池

@Configuration
@EnableAsync
public class ThreadPoolConfig implements AsyncConfigurer {

    @Override
    @Bean
    public Executor getAsyncExecutor() {
        ThreadPoolTaskExecutor executor = new ThreadPoolTaskExecutor();
        // 设置核心线程数
        executor.setCorePoolSize(5);
        // 设置最大线程数
        executor.setMaxPoolSize(5);
        // 设置队列容量
        executor.setQueueCapacity(99);
        // 设置线程活跃时间(秒)
        executor.setKeepAliveSeconds(300);
        // 设置默认线程名称
        executor.setThreadNamePrefix("thread-");
        // 设置拒绝策略rejection-policy:当pool已经达到max size的时候,如何处理新任务 CALLER_RUNS:不在新线程中执行任务,而是有调用者所在的线程来执行
        executor.setRejectedExecutionHandler(new ThreadPoolExecutor.CallerRunsPolicy());
        // 等待所有任务结束后再关闭线程池
        executor.setWaitForTasksToCompleteOnShutdown(true);
        return executor;
    }

    @Override
    public AsyncUncaughtExceptionHandler getAsyncUncaughtExceptionHandler() {
        return new SimpleAsyncUncaughtExceptionHandler();
    }
}

之后直接在需要调用的方法上使用注解@Async即可

需要注意的点:在调用的类上面需要使用注解@Component,交给Spring容器管理。 

遇到的坑:因为楼主是使用junit测试,所以出现一个情况就是,主线程跑完了,异步线程还没跑完。没异常,但是一直没有执行成功。

原因:因为主线程跑完了,异步线程也被终结掉了。我傻了。居然是这么简单的问题。。。

后面发现,如果想要使用junit测试,主线程不终止的情况,则直接死循环即可,while(true){};

因为spring那边也是这样去处理

记录之。

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spring Boot,可以通过整合线程池来实现对多线程任务的管理和调度。当我们启动Spring Boot项目时,可以在Spring容器注入一个线程池,并通过@Resource或@Autowired注解将其注入到需要使用线程池的类线程池的原理类似于数据库连接池,它将多个线程对象放入一个池子,可以从池子获取、使用和回收线程。每个线程在一段时间内只能执行一个任务,而线程池的各个线程是可以重复使用的。这样可以提高线程的复用性和效率。 在Spring Boot整合线程池的步骤如下: 1. 创建线程池配置类,使用@ConfigurationProperties注解将配置文件以"thread.pool"开头的配置信息绑定到对应的字段上。例如,配置文件的"thread.pool.core-pool-size"对应字段就是corePoolSize。同时,使用@Component注解将该类交由Spring容器管理。 2. 在配置类定义线程池的相关属性,包括核心线程数、最大线程数、空闲时间、等待队列长度等。 3. 在需要使用线程池的类,通过@Resource或@Autowired注解将线程池注入进来即可使用。 通过以上步骤,就可以在Spring Boot项目成功整合线程池,并且方便地使用线程池来处理多线程任务。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [spring boot整合线程池](https://blog.csdn.net/doubiy/article/details/124219390)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* [线程池详解+springboot整合线程池(超级详细简洁代码可直接执行)](https://blog.csdn.net/qq_40595922/article/details/120856971)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值