zoukankan      html  css  js  c++  java
  • spring boot自定义线程池以及异步处理

    spring boot自定义线程池以及异步处理@Async:
    什么是线程池?
    线程池是一种多线程处理形式,处理过程中将任务添加到队列,然后在创建线程后自动启动这些任务。线程池线程都是后台线程。每个线程都使用默认的堆栈大小,以默认的优先级运行,并处于多线程单元中。如果某个线程在托管代码中空闲(如正在等待某个事件),则线程池将插入另一个辅助线程来使所有处理器保持繁忙。如果所有线程池线程都始终保持繁忙,但队列中包含挂起的工作,则线程池将在一段时间后创建另一个辅助线程但线程的数目永远不会超过最大值。超过最大值的线程可以排队,但他们要等到其他线程完成后才启动。

    什么是异步处理?
    一个可以无需等待被调用函数的返回值就让操作继续进行的方法

    思路
    使用@Async来标记异步方法

    实现
    1.创建ThreadPoolConfig类,注意,需标记@EnableAsync

    @Configuration
    @EnableAsync
    public class ThreadPoolConfig {

    //其他

    }
    2.定义defaultThreadPool

    @Bean
    public Executor defaultThreadPool() {
    ThreadPoolTaskScheduler executor = new ThreadPoolTaskScheduler();
    executor.setPoolSize(线程大小);
    executor.setThreadPriority(优先级);
    executor.setThreadNamePrefix(名称前缀);
    executor.initialize();
    return executor;
    }
    3.编写异步测试方法,注意,需标记@Async
    @Async
    public Future<String> async() throws InterruptedException {
    final long time = 5000;
    Thread.sleep(time);
    LOGGER.info("async exec");
    return new AsyncResult<>("job done");
    }
    4.调用异步方法(如无需获取返回值的话,可直接调用),这里的样例是等待异步方法执行,然后获得返回值的场景
    public String asyncWait() throws InterruptedException, ExecutionException {
    Future<String> msg = demoService.async();
    final long time = 10000;
    while (true) {
    if (msg.isDone()) {
    break;
    }
    Thread.sleep(time);
    }
    return msg.get();
    }







    人这辈子没法做太多事情,所以每做一件事都要做到精彩绝伦。 因为,这就是我的宿命。人生苦短,你明白吗? 所以这是我为人生做出的选择
  • 相关阅读:
    PHP添加Redis模块及连接
    Redis高级应用
    Redis常用命令
    Redis的数据类型及操作
    Redis下载及安装部署
    NoSQL介绍
    8种Nosql数据库系统对比
    JQ插件
    libcurl一般用法
    密钥对加密原理
  • 原文地址:https://www.cnblogs.com/junjun1578/p/10437989.html
Copyright © 2011-2022 走看看